×

EmberJS 教程

EmberJS 概述EmberJS 环境配置EmberJS 应用EmberJS 对象模型EmberJS 模板EmberJS 路由器EmberJS 组件EmberJS 模型EmberJS 视图EmberJS 控制器EmberJS 测试EmberJS 指定查询参数

Ember 对象模型

Ember 类的定义 初始化 继承Ember 类的扩展Ember 计算属性Ember 观察者Ember 数据绑定Ember 枚举Ember 第一章对象模型小结

Ember handlebars模板

Ember handlebars基础Ember handlebars条件表达式Ember handlebars遍历标签Ember handlebars显示对象键Ember handlebars属性绑定Ember {{link-to}} 助手Ember 路由 模板执行渲染顺序Ember {{action}} 助手Ember 表单元素Ember 调试助手Ember 工具类的助手Ember 第二章模板小结

Ember 路由

Ember 路由定义Ember 指定与路由关联的模型Ember 模板渲染Ember 路由重定向Ember 路由终止挑战和激活Ember loading error子路由Ember 查询参数Ember 异步路由

Ember 组件

Ember 组件定义Ember 属性传递Ember 包裹内容自定义包裹组件的HTML标签Ember 处理事件Ember action触发变化

Ember 控制器

Ember 控制器Ember 管理控制器的依赖关系

Ember 模型

Ember model简介Ember 定义模型Ember 记录查询Ember 新建、更新、删除记录Ember 设置记录到StoreEmber model的关联关系处理Ember 元数据Ember 自定义适配器Ember 自定义序列号器

Ember 测试

Ember 测试简介Ember 验收测试Ember 单元测试

Ember 处理事件


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

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

ember g component handle-events
ember g route component-route

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


{{yield}}

注意看组件类的实现:

//  app/components/handle-events.js

import Ember from 'ember';

export default Ember.Component.extend({
    click: function() {
        alert('click...');

        return true;  // 返回true允许事件冒泡到父组件
    },
    mouseLeave: function() {
        alert("mouseDown....");

        return true;
    }
});

在组件类中增加了两个事件clickmouseLeaver,一个是单击事件一个是鼠标移开事件。

调用组件的模板如下:


{{#handle-events}}
从我身上飘过或者点我都会触发事件~
{{/handle-events}}

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

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

2,发送行为

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

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

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

//  app/components/drop-target.js

import Ember from 'ember';

export default Ember.Component.extend({
    attribuBindings: ['draggable'],
    draggable: 'true',

    dragOver: function() {
        return false;
    },
    didDrop: function(event) {
        let id = event.dataTransfer.getData('text/data');
        this.sendAction('action', id);
    }
});

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


分类导航

关注微信下载离线手册

bootwiki移动版 bootwiki
(群号:472910771)