Ember API 笔记-Ember

Ember Namespace

Emberjs API:http://emberjs.com/api/
定义于:packages/ember-metal/lib/core.js:8
所属模块:ember-metal

说明:所有Ember方法与函数都定义在这个命名空间里。Ember可以用Em缩写代替。Ember-Runtime是一个提供Ember核心功能的框架,包括跨平台功能、属性观察、对象等。可配合其他跨平台js库一起使用,如jQuery。
核心框架Runtime基于jQuery API,并做了一些性能优化。

继承的方法
-无
自有的方法

-$

说明:jQuery的别名。
-A(arr)

参数:
@arr--类数组

返回:Ember.NativeArray

说明:从一个类数组对象创建一个本地的Ember.NativeArray。不会修改原始对象。

-addListener(obj, eventName, targetOrMethod, method)

参数:
@obj--对象
@eventName--字符串。事件名
@targetOrMethod--目标对象或函数
@method--函数或字符串。要在目标对象上调用的函数或函数名

说明:添加一个事件监听器。

-alias(methodName)

参数:
@methodName--字符串。方法或属性的名字

返回:Ember.Descriptor

说明:使一个属性或方法可以通过额外的名字访问。

App.PaintSample = Ember.Object.extend({
  color: 'red',
  colour: Ember.alias('color'),
  name: function(){
    return "Zed";
  },
  moniker: Ember.alias("name")
});
var paintSample = App.PaintSample.create()
paintSample.get('colour'); //=> 'red'
paintSample.moniker(); //=> 'Zed'
-assert(desc, test)

参数:
@desc--字符串。用于断言失败时抛出异常的描述
@test--布尔值。一个用于断言的表达式,为真时跳过断言。如果是假,将抛出异常

说明:定义一个断言,当条件不匹配时(test结果是false),抛出异常,异常信息为desc。使用用于生产环境的版本时,Ember构建工具将屏蔽该方法。

// Test for truthiness
Ember.assert('Must pass a valid object', obj);
// Fail unconditionally
Ember.assert('This code path should never be run')
-beforeObserver(func, propertyNames)

参数:
@func--函数
@propertyNames--字符串

返回:func

说明:无相关信息,Ember中的源代码如下

Ember.beforeObserver = function(func) {
  var paths = a_slice.call(arguments, 1);
  func.__ember_observesBefore__ = paths;
  return func;
};
-bind(obj, to, from)

参数:
@obj--根对象
@to--字符串。与obj相关的目标路径
@from--字符串。来源路径,与obj相关的路径或全局路径

返回:Ember.Bingding实例

说明:创建新绑定的全局方法。传递根对象与目标和来源路径来创建和连接绑定。

Ember中的源码如下

Ember.bind = function(obj, to, from) {
  return new Ember.Binding(to, from).connect(obj);
};
-cacheFor(obj, key)

参数:
@obj--待检查的对象
@key--字符串。要返回缓存值的属性名

返回:缓存的属性值,如果有

说明:如果存在,返回属性的缓存值。对于查看计算属性会有用。

-canInvoke(obj, methodName)

参数:
@obj--待检查的对象
@method--待检查的方法名

返回:布尔值

说明:检查method是否存在obj上。

-compare(v, w)

参数:
@v--第一个比较对象
@w--第二个比较对象

返回:如果v<w,返回-1;如果v=w,返回0;如果v>w,返回1

说明:比较两个javascript值。如果类型不同,比较的顺序是基于Ember.ORDER_DEFINITION计算的。

Ember.compare('hello', 'hello'); // 0
Ember.compare('abc', 'dfg'); // -1
Ember.compare(2, 1); // 1
-computed(func)

参数:
@func--计算属性的计算函数

返回:Ember.ComputedProperty实例

说明:这个辅助函数返回一个新的属性描述符,包装传入的计算属性函数。您可以使用这个辅助函数或通过Ember.defineProperty()来定义混合属性。

传递的函数将被用来获取和设置属性值。该函数接受两个参数,键和值。如果值是未定义的,你应该先设定值。在任一情况下,返回属性的当前值。

-computed.bool(dependentKey)

参数:
@dependentKey--字符串

说明:暂无

-computed.empty(dependentKey)

参数:
@dependentKey--字符串

说明:暂无

-computed.not(dependentKey)

参数:
@dependentKey--字符串

说明:暂无

-copy(object, deep)

参数:
@object--被克隆的对象
@deep--布尔值。true表示使用深度拷贝

返回:克隆的新对象

说明:创建传递参数对象的一个拷贝。此功能可以拷贝任何类型的对象,包括原始值(实际上并没有克隆,因为它们是不可变的)。

如果传递的参数对象本身有clone()(必须是继承自Ember.Copyable)方法,则执行该方法并返回结果。

-create()

说明:相当于Object.create(),如果本身不可实现。

-deprecate(message, test)

参数:
@message--字符串
@test--布尔值

说明:显示警告,包含提供的message和堆栈信息。使用用于生产环境的版本时,Ember构建工具将屏蔽该方法。

-deprecateFunc(message, func)

参数:
@message--字符串
@func--函数

说明:当包装函数被调用时,显示警告,包含提供的message和堆栈信息。

-destroy(obj)

参数:
@obj--待销毁的对象

说明:删除对象元信息,该对象将被回收。多次调用不会产生副作用。

-empty(obj)

参数:
@obj--待检测的对象

返回:布尔值

说明:验证参数是否null或一个空的string、array。

Ember.empty(); => true
Ember.empty(null); => true
Ember.empty(undefined); => true
Ember.empty(''); => true
Ember.empty([]); => true
Ember.empty('tobias fünke'); => false
Ember.empty([0,1,2]); => false
Ember.empty({});     => false
-get(obj, keyName)

参数:
@obj--待检索的对象
keyName--检索的属性名

返回:属性值或null

说明:获取对象上的属性。如果时计算属性,计算函数将被调用。如果属性未定义,执行unknownProperty()方法。

在IE8或以前的浏览器,你应该使用该方法来检索对象属性。

如果对象为null,该方法返回undefined。

-immediateObserver(func, propertyNames)

参数:
@func--函数
@propertyName--字符串

返回:func

-inspect(obj)

参数:
@obj--待审查的对象

返回:字符串。被审查对象的描述

说明:审查对象的便捷方法。该方法将尝试转换对象为有用的描述语。

Ember.inspect( Ember.Object.create({
  firstName: 'Hansi',
  lastName: 'Hinterseer',
  age: 58
})); 
//"{firstName: Hansi , lastName: Hinterseer , age: 58}"
-isArray(obj)

参数:
@obj--待检测的对象

返回:布尔值

说明:如果传递的参数是数组或类数组,返回true。

Ember中判断Array的规则:

对象拥有一个objectAt属性
对象是本地数组
对象是一个Obejct,且有一个length属性

不像Ember.typeOf,即使传递的参数不是正规数组,只要是类数组(比如Ember.Array实现的数组),这个方法就会返回true。

Ember.isArray(); // false
Ember.isArray([]); // true
Ember.isArray( Ember.ArrayProxy.create({ content: [] }) ); // true
-isEqual(a, b)

参数:
@a--第一个比较对象
@b--第二个比较对象

返回:布尔值

说明:比较两个对象,如果他们逻辑上相等,返回true。相比===全等比较符,该方法采用深度比较。它会比较内部的对象。如果两个比较对象中,任意一个含有isEuqal()的对象,直接调用该方法并返回结果,不进行比较。对于数组不进行比较,因为对数组进行比较耗费的资源太大,即使数组相同,也返回false。

Ember.isEqual('hello', 'hello'); => true
Ember.isEqual(1, 2); => false
Ember.isEqual([4,2], [4,2]); => false
-K

返回:this

说明:简单的返回自身。某些情况下会有用。在模板中使用{{action}}并分配一个Ember.K方法给它,可以避免开发过程中,指定的目标对象不能处理动作时抛出异常的麻烦。

Ember.View.create({
  templateName: 'menu',
  home: Ember.K,
  profile: Ember.K,
  links: Ember.K
});
<ul>
  <li {{action "home"}} >Home</li>
  <li {{action "profile"}} >Profile</li>
  <li {{action "links"}} >Links</li>
</ul>
-keys(obj)

参数:
@obj--对象

返回:对象键组成的数组

说明:返回所有对象或哈希表上定义的键。调试时审查对象会有用。

var obj = Ember.Object.create({
  firstName: 'Hansi',
  lastName: 'Hinterseer',
  age: 58
})
Ember.keys(obj);    //["firstName", "lastName", "age"]
-makeArray(obj)

参数:
@obj--要转换为数组的对象

返回:数组

说明:将传递的参数转换成数组,但不改变原对象。如果参数对象以及是数组,则返回该对象。否则将添加该参数对象到一个数组。如果参数是null或undefined,返回空数组。

Ember.makeArray(); => []
Ember.makeArray(null); => []
Ember.makeArray(undefined); => []
Ember.makeArray('lindsay'); => ['lindsay']
Ember.makeArray([1,2,42]); => [1,2,42]
var controller = Ember.ArrayProxy.create({ content: [] });
Ember.makeArray(controller) === controller; => true
-mixin(obj, mixins)

参数:
@obj--对象
@mixins--混合类

返回:obj

-none(obj)

参数:
@obj--待检测的对象

返回:布尔值

说明:如果传递的参数是null或undefined,返回true。当使用==时会在JSLint测试中出现错误,可以用该方法代替来避免。

Ember.none(); => true
Ember.none(null); => true
Ember.none(undefined); => true
Ember.none(''); => false
Ember.none([]); => false
Ember.none(function(){}); => false
-observer(func, propertyNames)

参数:
@func--函数。属性更改时调用
@propertyNames--字符串。要观察的属性名

返回:func

说明:添加属性观察者。

var obj = Ember.Object.create({
  num:'1',
  change:Em.observer(function(){
  console.log('num change to '+this.num);
  },'num')
});
obj.set('num','2'); => num change to 2
-onLoad(name, callback)

参数:
@name--挂钩名称
@callback--回调函数

-oneWay(obj, to, from)

参数:
@obj--根对象
@to--字符串。与obj相关的目标路径
@from--字符串。来源路径,与obj相关的路径或全局路径

返回:Ember.Binding实例

说明:创建单向绑定的全局方法。

Ember中的源码如下

Ember.oneWay = function(obj, to, from) {
  return new Ember.Binding(to, from).oneWay().connect(obj);
};
-propertyDidChange(obj, keyName)

参数:
@obj--属性已经更改的对象
@keyName--已经更改的属性名(或路径)

说明:当属性更改后调用。它会通知任何观察者并清除缓存。

一般不需要直接去调用该方法,但如果因为某些原因不能直接监控某个属性,你可以手动调用,在属性值更改之前需调用Ember.propertyWillChange()。

-propertyWillChange(obj, keyName)

参数:
@obj--属性即将更改的对象
@keyName--即将更改的属性名(或路径)

说明:当属性更改前调用。它会通知任何观察者并准备缓存。

一般不需要直接去调用该方法,但如果因为某些原因不能直接监控某个属性,你可以手动调用,在属性值更改之后需调用Ember.propertyDidChange()。

-removeListener(obj, eventName, targetOrMethod, method)

参数:
@obj--调用方法的对象
@eventName--事件名
@targetOrMethod--目标对象或方法
@method--方法或方法名

说明:移除一个事件监听者。参数必须与传递给Ember.addListener的参数相匹配。

-renderBuffer(tagName)

参数:
@targetName--字符串

返回:Ember.RenderBuffer

说明:用传递的tagName创建新的renderBuffer。可以覆盖此方法来进一步定制,一般不需要调用或覆写。

-required()

返回:REQUIRED

说明:Denotes a required property for a mixin

-runLoadHooks(name, object)

参数:
@name--挂钩名
@object--传递给回调函数的对象

-sendEvent(obj, eventName, params)

参数:
@obj--对象
@eventName--事件名
@params--数组

返回:true

-set(obj, keyName, value)

参数:
@obj--要修改的对象
@keyName--要修改的属性名
@value--要设置的值

返回:对象。传递的值

说明:在对象上设置属性值。对于为定义的属性,调用unknownProperty()。

在IE8或以前的浏览器,你应该使用该方法来设置对象属性。

-tryInvoke(obj, methodName, args)

参数:
@obj--检查的对象
@methodName--字符串。检查的方法名
@args--数组。传递给methodName的参数

返回:methodName返回的值或undefined

说明:检查obj是否存在methodName方法,如果有,调用它,并传递args作为参数。

-trySet(obj, keyName, value)

参数:
@obj--要修改的对象
@keyName--要设置的属性
@value--要设置的值

说明:Ember.set的容错形式。主要用于同步绑定时尝试更新一个销毁的对象。

-typeOf(item)

参数:
@item--待检测的对象

返回:字符串。对象的类型

说明:返回参数对象的类型。使用此方法代替内建的typeof方法来获取对象的类型。它在所有浏览器都返回同样结果,并且包含更多细节。

Return Value Meaning
'string' String primitive
'number' Number primitive
'boolean' Boolean primitive
'null' Null value
'undefined' Undefined value
'function' A function
'array' An instance of Array
'class' A Ember class (created using Ember.Object.extend())
'instance' A Ember object instance
'error' An instance of the Error object
'object' A JavaScript object not inheriting from Ember.Object

示例

Ember.typeOf(); => 'undefined'
Ember.typeOf(null); => 'null'
Ember.typeOf(undefined); => 'undefined'
Ember.typeOf('michael'); => 'string'
Ember.typeOf(101); => 'number'
Ember.typeOf(true); => 'boolean'
Ember.typeOf(Ember.makeArray); => 'function'
Ember.typeOf([1,2,90]); => 'array'
Ember.typeOf(Ember.Object.extend()); => 'class'
Ember.typeOf(Ember.Object.create()); => 'instance'
Ember.typeOf(new Error('teamocil')); => 'error'
// "normal" JavaScript object
Ember.typeOf({a: 'b'}); => 'object'
-warn(message, test)

参数:
@message--字符串。警告信息内容
@test--布尔值。可选。如果为假,警告信息将显示

说明:显示警告信息message。使用用于生产环境的版本时,Ember构建工具将屏蔽该方法。

Ember.warn('Ah, we have a problem!', Ember.isEqual([1,2],[1,2]))
=> WARNING: Ah, we have a problem!

继承的属性
-无
自有的属性

-ENV

说明:标准环境变量。在加载Ember之前,定义全局ENV变量来控制各种配置设置。属性值为哈希表。

-EXTEND_PROTOTYPES

默认值:true

说明:用于决定是否增强javascript内建原型来提供更友好的API。如果开启,一些方法将添加到包装对象Function、String、Array上,Object.prototype不会得到增强,以避免麻烦。

在一般情况下我们建议保留此选项设置为true,因为它很少与其他代码冲突。如果您需要将其关闭,你可以定义ENV.EXTEND_PROTOTYPES配置来禁用它。

-LOG_BINDINGS

默认值:false

说明:开启时,将在控制台输出所有触发绑定更改的信息。在产品代码中应禁用。可以在控制台临时开启。

Ember.LOG_BINDINGS = true;
App = Ember.Application.create();
App.controller = Ember.Object.create({
  name: 'Nellie'
});
App.boundController = Ember.Object.create({
  nameBinding: 'App.controller.name'
});
App.boundController.set('name', 'Tobias');
> Begin: Flush Sync Queue 
> Ember.Binding<ember116>(App.controller.name -> name) <- Tobias {name: "Tobias", nameBinding: f}
> End: Flush Sync Queue
-LOG_STACKTRACE_ON_DEPRECATION

默认值:true

说明:决定当出现警告信息时是否在控制台输出完整的堆栈信息。

-SHIM_ES5

默认值:Ember.EXTEND_PROTOTYPES

说明:决定是否为旧浏览器添加ECMAScript 5 shims[shims主要目的是解决HTML5元素在旧IE下的样式问题]

-STRINGS

说明:属性值为哈希表。定义当前语言本地化字符串哈希表。通过Ember.String.loc()使用。参阅loc()。

-TEMPLATES

说明:全局共享模板哈希表。你可以将Handlebars模板存放在独立文件,在生成时构建工具会自动将模板加载到JavaScript。

-VERSION

默认值:'1.0.0-pre.2'

说明:版本号,常量。

-parentView

默认值:null

说明:如果视图当前已插入到DOM中的一个父视图,这个属性将指向该父视图。

事件

-onerror(error)

参数:
@error--错误事件对象

说明:分配一个函数给Ember.onerror,当Ember内部遇到错误时执行该函数。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,231评论 0 4
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,944评论 6 13
  • 真实的想法是:我想辞职走人 这是心声 我想任性地走掉
    我喜欢碎碎念阅读 202评论 2 0
  • 搁下毛笔,望着窗外的夜幕,觉得自己像是一个失爱孤儿,陪伴自己的只有这些笔墨和到处散放的书籍,还有最近的追剧!其实越...
    花样儿阅读 150评论 0 0
  • 仿佛一夜之间,有一件事突然进入我们的生活,随处可见,随时随地都能骑到的共享单车,无疑一下点亮了我们的这个小城市。 ...
    风蕾同舟阅读 984评论 0 0