在Ember.js中,枚举是包含许多子对象的任何对象,并允许你使用Ember.Enumerable API和那些子对象一起工作。在大部分应用程序中最常见的可枚举是本地JS数组,Ember.js扩展到符合可枚举接口。

通过提供一个标准化的接口处理来可枚举,ember.js让你彻底改变存储的底层数据的方式而无需修改应用程序的其他部分获取它。

可枚举的API尽可能遵循ECMAScript标准。这样最大限度的减少与其他库的不兼容,并允许Ember.js在数组中使用原生的浏览器实现。

例如,所有的可枚举支持标准的forEach方法:

[1,2,3].forEach(function(item) {
console.log(item);
}); //=> 1
//=> 2
//=> 3

通常,可枚举的方法,例如forEach,第二个参数是可选的,这个回调函数中将变成this的值在。

var array = [1,2,3];

array.forEach(function(item) {
console.log(item, this.indexOf(item));
}, array) //=> 1 0
//=> 2 1
//=> 3 2

一、Enumberables in Ember.js

通常,对象表示列表实现枚举器接口。

examples:

  • Array -- Ember使用可枚举的接口扩展JS原生的Array(除非你禁用属性扩展)
  • Ember.Set -- 一个数据结构,它可以有效回答是否它包含一个对象。

二、API概览

下面我们会探讨一些最常见的可枚举的便利。

1. Iterating Over An Enumerable(迭代)

使用forEach方法枚举所有可枚举对象的值:

var food = ["Poi", "Ono", "Adobo Chicken"];

food.forEach(function(item, index) {
console.log('Menu Item %@: %@'.fmt(index+1, item));
}); // Menu Item 1: Poi
// Menu Item 2: Ono
// Menu Item 3: Adobo Chicken

2. Making An Array Copy

通过调用toArray()方法你可以制作一个任何实现了Ember.Enumerable的对象的原生数组的拷贝。

var states = Ember.Set.create();

states.add("Hawaii");
states.add("California") states.toArray()
//=> ["Hawaii", "California"]

注意在许多的可枚举中,例如例子中使用的Ember.Set,所得到的数组的顺序是没有保证的。

3. First and Last Objects

所有的枚举接口暴露firstobjectlastobject属性可以绑定。

var animals = ["rooster", "pig"];

animals.get('lastObject');
//=> "pig" animals.pushObject("peacock"); animals.get('lastObject');
//=> "peacock"

4. Map

使用Map()方法你可以很容易地变化可枚举中的每一项,它可以调用每一项上回调函数的结果来创建一个新数组。

var words = ["goodbye", "cruel", "world"];

var emphaticWords = words.map(function(item) {
return item + "!";
});
// ["goodbye!", "cruel!", "world!"]

如果可枚举的是合成的,会有一个mayBy()方法,它将反过来从这些对象中的每一项中提取指定的属性并返回一个新数组。

var hawaii = Ember.Object.create({
capital: "Honolulu"
}); var california = Ember.Object.create({
capital: "Sacramento"
}); var states = [hawaii, california]; states.mapBy('capital');
//=> ["Honolulu", "Sacramento"]

5. Filtering

另一个常见的任务是以枚举作为输入执行一个枚举,和基于一些条件过滤后返回一个数组。

对于任意的过滤,用过滤器方法。如果包含在最后的数组中,该过滤器的方法期望回调函数返回true,否则返回false或者undefined

var arr = [1,2,3,4,5];

arr.filter(function(item, index, self) {
if (item < 4) { return true; }
}) // returns [1,2,3]

当使用一个集合对象时,通常需要根据某些属性的值来筛选一组对象。filterBy方法提供了一个快捷方式。

Todo = Ember.Object.extend({
title: null,
isDone: false
}); todos = [
Todo.create({ title: 'Write code', isDone: true }),
Todo.create({ title: 'Go to sleep' })
]; todos.filterBy('isDone', true); // returns an Array containing only items with `isDone == true`

如果你只需要返回第一个匹配的值,而不是包含所有匹配的值的数组,你可以使用findfindBy,它们只返回一条数据。

6. Aggregate Information(All or Any)汇总信息

如果你想找到可枚举中的每一条数据都满足一些条件,你可以使用every方法。

Person = Ember.Object.extend({
name: null,
isHappy: false
}); var people = [
Person.create({ name: 'Yehuda', isHappy: true }),
Person.create({ name: 'Majd', isHappy: false })
]; people.every(function(person, index, self) {
if(person.get('isHappy')) { return true; }
}); // returns false

如果你想找到可枚举中的至少一条数据都满足一些条件,你可以使用some方法。

people.some(function(person, index, self) {
if(person.get('isHappy')) { return true; }
}); // returns true

就像过滤方法一样,every和some有类似的方法isEveryisAny方法。

people.isEvery('isHappy', true) // false
people.isAny('isHappy', true) // true

2.8 The Object Model -- Enumerables的更多相关文章

  1. Selenium的PO模式(Page Object Model)[python版]

     Page Object Model 简称POM  普通的测试用例代码: .... #测试用例 def test_login_mail(self): driver = self.driver driv ...

  2. 在C#开发中如何使用Client Object Model客户端代码获得SharePoint 网站、列表的权限情况

    自从人类学会了使用火,烤制的方式替代了人类的消化系统部分功能,从此人类的消化系统更加简单,加速了人脑的进化:自从SharePoint 2010开始有了Client Side Object Model ...

  3. Selenium的PO模式(Page Object Model)|(Selenium Webdriver For Python)

            研究Selenium + python 自动化测试有近两个月了,不能说非常熟练,起码对selenium自动化的执行有了深入的认识. 从最初无结构的代码,到类的使用,方法封装,从原始函数 ...

  4. 解决在使用client object model的时候报“object does not belong to a list”错误

    在查看别人代码的时候,发现了个有意思的问题,使用client object model将一个文件check in 我使用的是如下语句获取file Microsoft.SharePoint.Client ...

  5. Page Object Model (Selenium, Python)

    时间 2015-06-15 00:11:56  Qxf2 blog 原文  http://qxf2.com/blog/page-object-model-selenium-python/ 主题 Sel ...

  6. SharePoint Client Object Model API 介绍以及工作原理解析

    CSOM和ServerAPI 的对比 SharePoint从2010开始引入了Client Object Model的API(后文中用CSOM来代替),从名字来看,我们可以简单的看出,该API是面向客 ...

  7. BOM (Browser Object Model) 浏览器对象模型

    l对象的角色,因此所有在全局作用域中声明的变量/函数都会变成window对象的属性和方法; // PS:尝试访问未声明的变量会抛出错误,但是通过查询window对象,可以知道某个可能未声明的对象是否存 ...

  8. 文本对象模型(Document Object Model)

    本文内容: 1. 概述 2. DOM中的节点类型 3. DOM节点的选取 4. 存取元素属性 5.DOM元素的增删 6.小结 ★ 概述 文本对象模型(DOM)是一个能够让程序和脚本动态访问和更新文档内 ...

  9. 浏览器对象模型(BOM,Browser Object Model)

    本文内容     1.概述     2.windows与document     3.对话框     4.定时调用     5.URL解析与访问历史     6.浏览器和屏幕信息 ★概述     &q ...

随机推荐

  1. Spring Framework 官方文档学习(四)之Validation、Data Binding、Type Conversion(二)

    接前一篇 Spring Framework 官方文档学习(四)之Validation.Data Binding.Type Conversion(一) 本篇主要内容:Spring Type Conver ...

  2. 微软Azure、谷歌GAE、亚马逊AWS比較

       谷歌Google App Engine 亚马逊AWS 微软Microsoft Azure 提供服 务类型 PaaS, SaaS Iaas, PaaS IaaS, PaaS, SaaS 服务间 ...

  3. quick-cocos2d-x游戏开发【10】——触摸捕获事件 cc.NODE_TOUCH_CAPTURE_EVENT

    假设看过sample中touch的代码,你会发现演示样例中有一个cc.NODE_TOUCH_CAPTURE_EVENT事件.它和cc.NODE_TOUCH_EVENT触摸事件一样,是引擎级别的事件,我 ...

  4. Linux中下载、解压、安装文件(转)

    原文地址:http://www.cnblogs.com/red-code/p/5539399.html 一.将解压包发送到linux服务器上: 1.在windos上下载好压缩包文件后,通过winscp ...

  5. cgitb--CGI跟踪模块(简化异常调试)

    通过启动cgitb模块,可以在web浏览器窗口查看详细的编码异常信息,而不必不停地跳转到web服务器的日志屏幕查看,更方便的定位问题: 异常解决后需关闭CGI跟踪. 在CGI脚本最前面增加如下两行,启 ...

  6. help()

    help() 用于查看函数或模块的帮助信息 In [1]: help(id) # 查看id()这个函数的帮助信息,注意不要写成help(id()) id(...) id(object) -> i ...

  7. C语言分支结构之if else语句

    前面我们看到的代码都是顺序执行的,也就是先执行第一条语句,然后是第二条.第三条……一直到最后一条语句,这称为顺序结构. 但是对于很多情况,顺序结构的代码是远远不够的,比如一个程序限制了只能成年人使用, ...

  8. EF更新的时候出错

    错误提示: 存储区更新.插入或删除语句影响到了意外的行数(0).实体在加载后可能被修改或删除.刷新 ObjectStateManager 项. 说明: 执行当前 Web 请求期间,出现未经处理的异常. ...

  9. openstack将本地实例迁移至ceph存储中

    需求: 最近在openstack上线了ceph存储,创建虚拟机和云硬盘都基于ceph卷进行存储和创建,但是之前openstack用的是本地存储,创建的所有实例都在本地文件中,当实例重启之后,opens ...

  10. R向量匹配match和pmatch

    match(x, table, nomatch = NA_integer_, incomparables = NULL) x: 向量, 要匹配的值; table: 向量, 被匹配的值; nomatch ...