国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

JavaScript的Polymer框架中dom-repeat與VM的相關操作

2024-05-06 16:24:01
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了JavaScript的Polymer框架中dom-repeat與VM的相關操作,Polymer是由Ggoogle開發的Web UI相關框架,需要的朋友可以參考下

各種框架都有把一個列表數據綁定到 DOM 上的功能,比如 Angular 會用 ng-repeat 來綁定。那么 Polymer 呢?其實這個級別的功能屬于框架的擴展功能了,Angular 的 ng-repeat 也只是個 Directive 而已。Polymer 的 dom-repeat 也是這個級別的東西。

在 Polymer 中,一切都是 Directive 的概念。dom-module 用于定義模塊,它本身也是一個 Directive。dom-repeat 也是,但它不是一個標簽,而是一個基于 template 標簽的 Directive。我們可以這樣使用它:

運行

 

 
  1. <script> var Polymer = { dom: 'shadow' }; </script> 
  2. <base href="http://www.web-tinker.com/share/" /> 
  3. <link rel="import" href="polymer/polymer.html" /> 
  4.  
  5. <dom-module id="demo-test"
  6. <template> 
  7. <ul> 
  8. <template is="dom-repeat" items="[[data]]"
  9. <li> 
  10. 第 <strong>[[index]]</strong> 項, 
  11. 值為 <strong>[[item]]</strong> 
  12. </li> 
  13. </template> 
  14. </ul> 
  15. </template> 
  16. <script> 
  17. Polymer({ 
  18. is: 'demo-test'
  19. properties: { 
  20. data: { 
  21. type: Array, 
  22. value: [ 'a''b''c''d' ] 
  23. }); 
  24. </script> 
  25. </dom-module> 
  26.  
  27. <demo-test></demo-test> 

上面的代碼對某個 template 元素設置 is 屬性為 dom-repeat,于是這個 template 元素內的東西就被循環了。這個循環根據在 template 元素上提供的 items 屬性來遍歷。注意 items 必須是數組,雖然用起來可能有點不太方便,但我覺得這個限制是一個非常好的做法。避免了像 Angular 那樣使用 for-in 去遍歷導致的各種問題。

items 的每一項,其索引和值會被放入 index 和 item 這兩個屬性中供 template 內的模板使用,于是上面的例子就輸出了給定的索引和值。

然而 Polymer 的數據更新并不是基于臟數據比對,所以數據的動態更新可能就有點麻煩。比如我們有一個按鈕,每次點擊要增加一項的話應該這么寫

運行

 

 
  1. <script> var Polymer = { dom: 'shadow' }; </script> 
  2. <base href="http://www.web-tinker.com/share/" /> 
  3. <link rel="import" href="polymer/polymer.html" /> 
  4.  
  5. <dom-module id="demo-test"
  6. <template> 
  7. <input placeholder="請輸入內容" value="{{value::input}}" /> 
  8. <button on-click="append">添加一項</button> 
  9. <ul> 
  10. <template is="dom-repeat" items="[[data]]"
  11. <li> 
  12. 第 <strong>[[index]]</strong> 項, 
  13. 值為 <strong>[[item]]</strong> 
  14. </li> 
  15. </template> 
  16. </ul> 
  17. </template> 
  18. <script> 
  19. Polymer({ 
  20. is: 'demo-test'
  21. properties: { 
  22. data: { 
  23. type: Array, 
  24. value: [ 'a''b''c''d' ] 
  25. }, 
  26. append: function() { 
  27. // data.push(this.value); // 這么寫是不行的 
  28. this.push('data'this.value) 
  29. }); 
  30. </script> 
  31. </dom-module> 
  32.  
  33. <demo-test></demo-test> 

之前我們說過,Polymer 會將需要監控變化的數據作為一個訪問器屬性來設置,但如果改變數組的元素,實際上并沒有對數組本身有任何改動。當我們把一個數組賦值給 VM 時實際上是把元素復制過去,而不是把數組對象丟過去。也就是說,這個數組對象并不直接是 VM 的引用,操作這個數組對象是無法影響 VM 的,所以直接對數組做 push 只是對數據的 push。

雖然數組自己的 push 方法無法操作 VM,但 Polymer 自己也提供了一些直接操作 VM 的方法,比如上面例子中的 this.push 就是 Polymer 提供的。它的操作模板不是一個對象,而是 VM 上的一個訪問路徑(比如上面例子中 push 的第一個參數 'data' 就是 VM 中 data 訪問路徑)。

除了 push 之外還有 pop、shift 等一些類似原生方法的操作(但要注意他們不是元素方法)。雖然操作起來確實不太方便,但也不至于到惡心的程度,反正我是勉強能接受的。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 思南县| 黔南| 开江县| 永平县| 平远县| 博湖县| 梁河县| 广州市| 德庆县| 呼伦贝尔市| 察隅县| 崇信县| 兰考县| 防城港市| 印江| 汽车| 开化县| 贵溪市| 嵊州市| 江源县| 蛟河市| 定兴县| 南郑县| 云浮市| 海门市| 景谷| 醴陵市| 理塘县| 教育| 游戏| 台东县| 抚顺市| 彭泽县| 双桥区| 宜宾县| 建宁县| 丰宁| 曲阳县| 东至县| 江口县| 德钦县|