课程表

Ember.js 基础

Ember.js 对象模型

Ember.js handlebars模板

Ember.js 路由

Ember.js 组件

Ember.js 控制器

Ember.js 模型

Ember.js 测试

工具箱
速查手册

处理事件

当前位置:免费教程 » JS/JS库/框架 » Ember.js

你可以在组件中响应事件,比如用户的双击、鼠标滑过、键盘的按下等等事件。只需要在组件类中增加Ember提供的处理事件,然后Ember会自动判断用户的操作执行相应的事件,只要在组件类中添加的事件不冲突你甚至一次性增加多个事件,事件执行次序根据触发的次序执行。

1,简单事件处理
准备工作,使用Ember CLI创建演示所需文件:

  1. ember g component handle-events
  2. ember g route component-route

生成的组件模板不做任何修改。

  1. <!-- app/components/handle-events.hbs -->
  2. {{yield}}

注意看组件类的实现:

  1. // app/components/handle-events.js
  2. import Ember from 'ember';
  3. export default Ember.Component.extend({
  4. click: function() {
  5. alert('click...');
  6. return true; // 返回true允许事件冒泡到父组件
  7. },
  8. mouseLeave: function() {
  9. alert("mouseDown....");
  10. return true;
  11. }
  12. });

在组件类中增加了两个事件clickmouseLeaver,一个是单击事件一个是鼠标移开事件,更多Ember支持的事件请看handling-events

调用组件的模板如下:

  1. <!-- app/templates/component-route.hbs -->
  2. {{#handle-events}}
  3. <span style="cursor: pointer;">从我身上飘过或者点我都会触发事件~</span>
  4. {{/handle-events}}

当用户只是把鼠标从文字“从我身上飘过或者点我都会触发事件~”上划过市只执行mouseLeave事件,当用户点击文字时先执行click事件再执行mouseLeave事件,因为用户点击文字时鼠标还没移开。

但是如果你增加的事件是有冲突的可能会得到无法预知的结果,比如在组件类中增加了双击和单击事件,此时只会执行单击事件,双击事件就无法触发。

2,发送行为

某些情况下,你的组件需要支持拖放事件。比如组件可能要发送一个iddrop事件中。

  1. {{drop-target action=”didDrop”}}

你可以定义组件的事件处理器去管理drop事件。如果有需要可以通过返回false防止事件冒泡。

  1. // app/components/drop-target.js
  2. import Ember from 'ember';
  3. export default Ember.Component.extend({
  4. attribuBindings: ['draggable'],
  5. draggable: 'true',
  6. dragOver: function() {
  7. return false;
  8. },
  9. didDrop: function(event) {
  10. let id = event.dataTransfer.getData('text/data');
  11. this.sendAction('action', id);
  12. }
  13. });

本章内容不多,重点是第一点的内容,第二点的内容就简单介绍,更多详细信息请移步官网文档

转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号