Web 技术研究所

我一直坚信着,Web 将会成为未来应用程序的主流

初探 Polymer 1.0 之 事件绑定

  既然是一套完整的前端框架那就一定有提供事件绑定相关的支持。其实在之前的例子中就使用过事件绑定,只是没有单独系统地介绍过而已。 Polymer 的事件思想是对事件处理函数尽可能地都命名并定义到 VM 上,我觉得这个做法是在有意地把 VM 这一层隔离出来。
  下面这个例子给按钮和其所在的 Shadow DOM Host 都绑定了个事件,点击按钮后两个事件都会触发。 <script> var Polymer = { dom: 'shadow' }; </script>
<base href="http://www.web-tinker.com/share/" />
<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 href="http://www.web-tinker.com/share/" />
<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 如此设计的良苦用心吧?
网名:
3.80.32.*
电子邮箱:
仅用于接收通知
提交 悄悄的告诉你,Ctrl+Enter 可以提交哦
神奇海螺
[查看全部主题]
各类Web技术问题讨论区
发起新主题
本模块采用即时聊天邮件通知的模式
让钛合金F5成为历史吧!
次碳酸钴的技术博客,文章原创,转载请保留原文链接 ^_^