欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

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

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

<dom-module id="demo-test">
 <template>
  <button on-click="clickHandler">求點(diǎn)擊 (=~ω~=)</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 是一個(gè)用于給當(dāng)前 Shadow DOM Host 添加事件的(雖然我覺(jué)得它沒(méi)卵用)。直接在 DOM 元素上的 on-* 屬性也可以給某個(gè)元素綁定事件。這些方式綁定的都是 DOM 事件,事件觸發(fā)時(shí)傳遞過(guò)去的對(duì)象就是原生的事件對(duì)象。
  除了以上這些直接作為屬性設(shè)置的事件綁定方式之外,我們還可以動(dòng)態(tài)地綁定事件。
運(yùn)行

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

<dom-module id="demo-test">
 <template>
  <button>求點(diǎn)擊 (=~ω~=)</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 總是希望我們對(duì)事件處理函數(shù)命名,比如其自帶的 listen 方法對(duì)元素綁定的不是一個(gè)事件處理函數(shù),而是一個(gè)事件處理函數(shù)名。也許這么做的目的是將 VM 和 M 完全隔離開來(lái),但是我并不喜歡這樣。不過(guò) Shadow DOM Host 本身也是一個(gè)原生對(duì)象,所以直接使用原生的 addEventListener 也是可以的,不過(guò)既然框架內(nèi)有提供,我也不推薦寫原生。也許是我的思想太 low 的,無(wú)法領(lǐng)悟 Polymer 如此設(shè)計(jì)的良苦用心吧?

相關(guān)文章

  • js事件委托詳解

    js事件委托詳解

    在本篇文章里小編給大家整理的是一篇關(guān)于js事件委托詳解以及相關(guān)實(shí)例內(nèi)容,有興趣的朋友們可以跟著學(xué)習(xí)下。
    2021-11-11
  • JavaScript中Date對(duì)象的常用方法示例

    JavaScript中Date對(duì)象的常用方法示例

    這篇文章主要介紹了JavaScript中Date對(duì)象的常用方法示例,Date對(duì)象的相關(guān)運(yùn)用是JS入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-10-10
  • JavaScript var聲明變量背后的原理示例解析

    JavaScript var聲明變量背后的原理示例解析

    只要是寫過(guò)點(diǎn)JS代碼,很簡(jiǎn)單一個(gè)var 就完事了,那么JS編譯器背后它又發(fā)生了什么呢?在本文將為大家詳細(xì)介紹下,感興趣的朋友不要錯(cuò)過(guò)
    2013-10-10
  • javascript入門·對(duì)象屬性方法大總結(jié)

    javascript入門·對(duì)象屬性方法大總結(jié)

    javascript入門·對(duì)象屬性方法大總結(jié)...
    2007-10-10
  • javascript計(jì)時(shí)器事件使用詳解

    javascript計(jì)時(shí)器事件使用詳解

    通過(guò)使用JavaScript,能在一個(gè)設(shè)定的時(shí)間間隔之后來(lái)執(zhí)行代碼,而不是在函數(shù)被調(diào)用后立即執(zhí)行。我們稱之為計(jì)時(shí)事件,下面對(duì)javascript計(jì)時(shí)器事件做了詳細(xì)解釋
    2014-01-01
  • Knockout text綁定DOM的使用方法

    Knockout text綁定DOM的使用方法

    本文講解Knockout text綁定到DOM元素上,使得該元素顯示的文本值為你綁定的參數(shù)。該綁定在顯示<span>或者<em>上非常有用,可以用在任何元素上
    2013-11-11
  • javascript 數(shù)據(jù)類型轉(zhuǎn)換(parseInt,parseFloat)

    javascript 數(shù)據(jù)類型轉(zhuǎn)換(parseInt,parseFloat)

    Number、String函數(shù)是特殊的函數(shù),在JS引擎中,他會(huì)自動(dòng)判斷是作為構(gòu)造函數(shù)調(diào)用還是普通調(diào)用,所以既可以使用new關(guān)鍵字,也可以作為函數(shù)直接調(diào)用。
    2010-07-07
  • 詳解JavaScript ES6中的模板字符串

    詳解JavaScript ES6中的模板字符串

    這篇文章主要介紹了詳解JavaScript ES6中的模板字符串,JS的ES6版本帶來(lái)諸多簡(jiǎn)潔化方面的重大改進(jìn),需要的朋友可以參考下
    2015-07-07
  • JavaScript初級(jí)教程(第五課續(xù))

    JavaScript初級(jí)教程(第五課續(xù))

    JavaScript初級(jí)教程(第五課續(xù))...
    2007-04-04
  • JavaScript中的原型prototype屬性使用詳解

    JavaScript中的原型prototype屬性使用詳解

    這篇文章主要介紹了JavaScript中的原型prototype屬性使用詳解,是JS入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-06-06

最新評(píng)論