麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 語(yǔ)言 > JavaScript > 正文

JavaScript的Polymer框架中dom-repeat與VM的相關(guān)操作

2024-05-06 16:24:01
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

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

各種框架都有把一個(gè)列表數(shù)據(jù)綁定到 DOM 上的功能,比如 Angular 會(huì)用 ng-repeat 來(lái)綁定。那么 Polymer 呢?其實(shí)這個(gè)級(jí)別的功能屬于框架的擴(kuò)展功能了,Angular 的 ng-repeat 也只是個(gè) Directive 而已。Polymer 的 dom-repeat 也是這個(gè)級(jí)別的東西。

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

運(yùn)行

 

 
  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> 項(xiàng), 
  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> 

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

items 的每一項(xiàng),其索引和值會(huì)被放入 index 和 item 這兩個(gè)屬性中供 template 內(nèi)的模板使用,于是上面的例子就輸出了給定的索引和值。

然而 Polymer 的數(shù)據(jù)更新并不是基于臟數(shù)據(jù)比對(duì),所以數(shù)據(jù)的動(dòng)態(tài)更新可能就有點(diǎn)麻煩。比如我們有一個(gè)按鈕,每次點(diǎn)擊要增加一項(xiàng)的話應(yīng)該這么寫

運(yùn)行

 

 
  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="請(qǐng)輸入內(nèi)容" value="{{value::input}}" /> 
  8. <button on-click="append">添加一項(xiàng)</button> 
  9. <ul> 
  10. <template is="dom-repeat" items="[[data]]"
  11. <li> 
  12. 第 <strong>[[index]]</strong> 項(xiàng), 
  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> 

之前我們說(shuō)過(guò),Polymer 會(huì)將需要監(jiān)控變化的數(shù)據(jù)作為一個(gè)訪問(wèn)器屬性來(lái)設(shè)置,但如果改變數(shù)組的元素,實(shí)際上并沒(méi)有對(duì)數(shù)組本身有任何改動(dòng)。當(dāng)我們把一個(gè)數(shù)組賦值給 VM 時(shí)實(shí)際上是把元素復(fù)制過(guò)去,而不是把數(shù)組對(duì)象丟過(guò)去。也就是說(shuō),這個(gè)數(shù)組對(duì)象并不直接是 VM 的引用,操作這個(gè)數(shù)組對(duì)象是無(wú)法影響 VM 的,所以直接對(duì)數(shù)組做 push 只是對(duì)數(shù)據(jù)的 push。

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

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 久久久久亚洲美女啪啪 | 日韩av片网站 | 国产色妞影院wwwxxx | 国产精品毛片va一区二区三区 | 国产精品一区二区三区99 | 欧美精品一区二区视频 | 国产一级做a爱片在线看免 2019天天干夜夜操 | 免费永久看羞羞片网站入口 | 毛片在线免费播放 | 国产免费高清 | 九九精品在线播放 | 在线观看一二区 | 国产精品久久久久久久久久尿 | 免费人成年短视频在线观看网站 | 激情网站免费观看 | 神马久久精品综合 | 女人久久久www免费人成看片 | 九九福利视频 | 爱看久久 | 亚洲日本韩国在线观看 | 久久99国产综合精品 | 欧美国产一级片 | 黄色国产在线观看 | 日本一区二区不卡在线观看 | 性大片1000免费看 | 在线播放的av网站 | 久久性生活免费视频 | 久久精品超碰 | xxxxxx免费 | 久久91亚洲人成电影网站 | 精品国产一区二 | 国产精品久久久久久238 | 国产一区二区视频网站 | 成人免费看片a | 精品一区二区在线观看视频 | 九九热精品免费视频 | 嫩草影院在线观看网站成人 | 免费在线观看成人av | 本色视频aaaaaa一级网站 | 国产高潮国产高潮久久久91 | 久久综合久久精品 |