亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

淺談JavaScript的Polymer框架中的事件綁定

 更新時間:2015年07月29日 11:51:04   投稿:goldensun  
這篇文章主要介紹了淺談JavaScript的Polymer框架中的事件綁定,Polymer是由Google開發(fā)的針對Web UI的框架,需要的朋友可以參考下

既然是一套完整的前端框架那就一定有提供事件綁定相關(guān)的支持。其實在之前的例子中就使用過事件綁定,只是沒有單獨系統(tǒng)地介紹過而已。 Polymer 的事件思想是對事件處理函數(shù)盡可能地都命名并定義到 VM 上,我覺得這個做法是在有意地把 VM 這一層隔離出來。
  下面這個例子給按鈕和其所在的 Shadow DOM Host 都綁定了個事件,點擊按鈕后兩個事件都會觸發(fā)。
運行

<script> var Polymer = { dom: 'shadow' }; </script>
<base  />
<link rel="import" href="polymer/polymer.html" />

<dom-module id="demo-test">
 <template>
  <button on-click="clickHandler">求點擊 (=~ω~=)</button>
 </template>
 <script>
  Polymer({
   is: 'demo-test',
   listeners: {
    'click': 'clickHandler'
   },
   clickHandler: function(e) {
    console.log(e.target);
   } 
  });
 </script>
</dom-module>

<demo-test></demo-test>

  listeners 是一個用于給當(dāng)前 Shadow DOM Host 添加事件的(雖然我覺得它沒卵用)。直接在 DOM 元素上的 on-* 屬性也可以給某個元素綁定事件。這些方式綁定的都是 DOM 事件,事件觸發(fā)時傳遞過去的對象就是原生的事件對象。
  除了以上這些直接作為屬性設(shè)置的事件綁定方式之外,我們還可以動態(tài)地綁定事件。
運行

<script> var Polymer = { dom: 'shadow' }; </script>
<base  />
<link rel="import" href="polymer/polymer.html" />

<dom-module id="demo-test">
 <template>
  <button>求點擊 (=~ω~=)</button>
 </template>
 <script>
  Polymer({
   is: 'demo-test',
   ready: function() {
    // Polymer 內(nèi)置
    this.listen(this, 'click', 'clickHandler');
    // 原生
    this.addEventListener('click', this.clickHandler);
   },              
   clickHandler: function(e) {     
    console.log(e);
   }
  });
 </script>
</dom-module>

<demo-test></demo-test>

  Polymer 總是希望我們對事件處理函數(shù)命名,比如其自帶的 listen 方法對元素綁定的不是一個事件處理函數(shù),而是一個事件處理函數(shù)名。也許這么做的目的是將 VM 和 M 完全隔離開來,但是我并不喜歡這樣。不過 Shadow DOM Host 本身也是一個原生對象,所以直接使用原生的 addEventListener 也是可以的,不過既然框架內(nèi)有提供,我也不推薦寫原生。也許是我的思想太 low 的,無法領(lǐng)悟 Polymer 如此設(shè)計的良苦用心吧?

相關(guān)文章

最新評論