入门指南 获取Ember 概念 对象模型 应用 模板 路由 组件 控制器 模型 视图 枚举 测式 配置Ember.js COOKBOOK 理解Ember.js

发布于 2015-08-18 16:31:23 | 270 次阅读 | 评论: 0 | 来源: 网络整理

视图在页面上表现为一个单一的DOM元素。通过修改tagName属性,可以改变视图生成的元素的类型。

 
1
2
3
App.MyView = Ember.View.extend({
  tagName: 'span'
});
 

另外,还可以通过设置一个字符串数组到classNames属性,来设置视图要应用的样式列表。

 
1
2
3
App.MyView = Ember.View.extend({
  classNames: ['my-view']
});
 

如果需要通过视图的属性来决定使用什么样式,那么可以采用样式名绑定。如果绑定了一个布尔属性,那么是否应用样式则有该属性的值来决定:

 
1
2
3
4
App.MyView = Ember.View.extend({
  classNameBindings: ['isUrgent'],
  isUrgent: true
});
 

上述的代码将会把视图渲染为:

 
1
<div class="ember-view is-urgent">
 

如果isUrgent变为false,那么is-urgent样式将被删除。

默认情况下,布尔属性的名称会采用中划线分割的方式命名。通过使用冒号来定界,可以自定义样式的名称。

 
1
2
3
4
App.MyView = Ember.View.extend({
  classNameBindings: ['isUrgent:urgent'],
  isUrgent: true
});
 

上述代码将渲染出如下的HTML:

 
1
<div class="ember-view urgent">
 

不仅可以在属性值为true的时候自定义样式名,同样也可以指定属性值为false的时候使用的样式名:

 
1
2
3
4
App.MyView = Ember.View.extend({
  classNameBindings: ['isEnabled:enabled:disabled'],
  isEnabled: false
});
 

上述代码将渲染出如下的HTML:

 
1
<div class="ember-view disabled">
 

另外,通过按照如下的方式声明classNameBindings,来指定只在属性为false的要使用的样式:

 
1
2
3
4
App.MyView = Ember.View.extend({
  classNameBindings: ['isEnabled::disabled'],
  isEnabled: false
});
 

上述代码将渲染出如下的HTML:

 
1
<div class="ember-view disabled">
 

如果isEnabled属性被设置为true,那么不会添加任何样式:

 
1
<div class="ember-view">
 

如果绑定的值是字符串,那么该值会直接作为样式名添加到视图:

 
1
2
3
4
App.MyView = Ember.View.extend({
  classNameBindings: ['priority'],
  priority: 'highestPriority'
});
 

上述代码将渲染出如下的HTML:

 
1
<div class="ember-view highestPriority">
 

视图属性绑定

通过attributeBindings可以直接绑定代表视图的DOM元素的属性:

 
1
2
3
4
5
App.MyView = Ember.View.extend({
  tagName: 'a',
  attributeBindings: ['href'],
  href: "http://emberjs.com"
});
 

也可以将这些属性绑定到其他命名的属性上:

 
1
2
3
4
5
App.MyView = Ember.View.extend({
  tagName: 'a',
  attributeBindings: ['customHref:href'],
  customHref: "http://emberjs.com"
});
 

在Handlebars中自定义视图元素

当追加一个视图的时候,其创建了一个新的HTML元素来存放其内容。如果视图含有子视图,子视图将作为父视图HTML元素的子节点来显示。

默认情况下,Ember.View的实例创建一个<div>元素。通过传入一个tagName参数可以覆盖这个默认行为:

 
1
{{view App.InfoView tagName="span"}}
 

同样传入id参数可以指定视图HTML元素的ID属性:

 
1
{{view App.InfoView id="info-view"}}
 

这使得可以容易的采用CSS ID选择器来定义样式:

 
1
2
3
4
/** Give the view a red background. **/
#info-view {
  background-color: red;
}
 

样式名称也可以采用类似的方式来指定:

 
1
{{view App.InfoView class="info urgent"}}
 

采用classBinding而不是class可以将样式名绑定到视图的一个属性。这与bind-attr的行为一致:

 
1
2
3
4
App.AlertView = Ember.View.extend({
  priority: "p4",
  isUrgent: true
});
 
 
1
{{view App.AlertView classBinding="isUrgent priority"}}
 

上述代码生成如下的视图包裹:

 
1
<div id="ember420" class="ember-view is-urgent p4"></div>
 
最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务