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

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 11:58:03
字體:
來源:轉載
供稿:網友

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

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

<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 內置    this.listen(this, 'click', 'clickHandler');    // 原生    this.addEventListener('click', this.clickHandler);   },                 clickHandler: function(e) {         console.log(e);   }  }); </script></dom-module><demo-test></demo-test>

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 蒙自县| 龙里县| 钟祥市| 南宫市| 鄢陵县| 青铜峡市| 宁晋县| 梁山县| 西畴县| 马龙县| 托克托县| 古丈县| 渝中区| 桦川县| 海盐县| 阿鲁科尔沁旗| 莎车县| 昌江| 鹤庆县| 文化| 临高县| 河北区| 凤山县| 三门县| 盐亭县| 南和县| 资中县| 望都县| 祁门县| 敦化市| 舞钢市| 平武县| 隆安县| 连平县| 淅川县| 右玉县| 武胜县| 恩平市| 会同县| 易门县| 垫江县|