×

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 handlebars属性绑定


简单讲属性绑定其实就是在HTML标签内(是在一个标签的””中使用)直接使用handlebars表达式。可以直接用handlebars表达式的值作为HTML标签中某个属性的值。

准备工作: ember generate route binding-element-attributes

1,绑定字符串


<div id="logo">
    <img src={{model.imgUrl}} alt='logo' />
</div>

在对应的route:binding-element-attributes里增加测试数据。

import Ember from 'ember';

export default Ember.Route.extend({
    model: function() {
        return { imgUrl: 'http://i1.tietuku.com/1f73778ea702c725.jpg' };
    }
});

运行之后模板会编译成如下代码:

<div id="logo">
    <img alt="logo" src="http://i1.tietuku.com/1f73778ea702c725.jpg">
</div>

可以看到{{model.imgUrl}}会以字符串的形式绑定到src属性上。

2,绑定Boolean值

在开发过程中我们经常会根据某个值判断是否给某个标签增加CSS类,或者根据某个值决定按钮是否可用等等……那么ember是怎么做的呢?? 比如下面的代码演示的是checkbox按钮根据绑定的属性isEnable的值决定是否可用。

{{! 当isEnable为true时候,disabled为true,不可用;否则可用}}
<input type='checkbox' disabled={{model.isEnable}}>

如果在route里设置的值是true那么渲染之后的HTML如下:

<input type="checkbox" disabled="">

否则

<input type="checkbox">

3, 绑定data-xxx属性

默认情况下,ember不会绑定到data-xxx这一类属性上。比如下面的绑定结果就得不到你的预期。

{{! 绑定到data-xxx这种属性需要特殊设置}}
{{#link-to 'photo' data-toggle='dropdown'}} link-to {{/link-to}}
{{input type='text' data-toggle='tooltip' data-placement='bottom' title="Name"}}

模板渲染之后得到下面的HTML代码

<a id="ember455" href="/binding-element-attributes" class="ember-view active"> link-to </a>
<input id="ember470" title="Name" type="text" class="ember-view ember-text-field">

可以看到data-xxx的属性都不见了!!!现在很多的前端框架都会用到data-xxx这个属性,比如bootstrap。那怎么办呢……你可以在view中指定对应的渲染组件Ember.LinkComponentEmber.TextField(个人理解的)。 执行命令得到view文件:
ember generate view binding-element-attributes
在view中手动绑定,如下:

//  app/views/binding-element-attributes.js

import Ember from 'ember';

export default Ember.View.extend({
});

//  下面是官方给的代码,但很明显看出来这种使用方式不是2.0版本的!!
//  2.0版本的写法还在学习中,后续在补上,现在为了演示模板效果暂时这么写!毕竟本文的重点还是在模板属性的绑定上

//  绑定input
Ember.TextField.reopen({
    attributeBindings: ['data-toggle', 'data-placement']
});

// //  绑定link-to
Ember.LinkComponent.reopen({
    attributeBindings: ['data-toggle']
});

渲染之后得到的结果符合预期。得到如下HTML代码

<a id="ember398" href="/binding-element-attributes" data-toggle="dropdown" class="ember-view active">link-to</a>
<input id="ember414" title="Name" type="text" data-toggle="tooltip" data-placement="bottom" class="ember-view ember-text-field">

可以看到data-xxx的属性正常渲染到HTML上了。

本文介绍了几个常用的属性绑定方式,非常之实用!但是有点遗憾本人能力有限还没理解到最后一个实例在Ember2.0版中是怎么使用的,现在的代码是根据个人理解把指定组件的代码放在view,官方教程给的也不是Ember2.0版的,所以binding-element-attributes.js这个文件的代码有点奇葩了……希望读者们不吝赐教!


分类导航

关注微信下载离线手册

bootwiki移动版 bootwiki
(群号:472910771)