现在的位置: 首页 > 综合 > 正文

Ext中apply及applyIf

2013年08月15日 ⁄ 综合 ⁄ 共 842字 ⁄ 字号 评论关闭

apply及applyIf方法都是用于实现把一个对象中的属性应用于另外一个对象中,相当于属性拷贝。不同的是apply将会覆盖目标对象中的属*,而applyIf只拷贝目标对象中没有而源对象中有的属性。

 

apply 方法的签名为“apply( Object obj, Object config, Object defaults ) : Object”,该方法包含三个参数,第一个参数是要拷贝的目标对象,第二个参数是拷贝的源对象,第三个参数是可选的,表示给目标对象提供一个默认值。可以简单的理解成把第三个参数(如果有的话)及第二个参数中的属性拷贝给第一个参数对象。看下面的代码:

 

PLAIN TEXT

 

 

var b1 = {
    p1: "p1 value",
    p2: "p2 value",
    f1: function() { alert(this.p2) }
};
var b2 = new Object();
b2.p2 = "b2 value";
Ext.apply(b2, b1);
b2.f1();

 


在上面的代码中,Ext.apply(b2,b1)这一语句把b1的属性拷贝到了b2对象中,因此调用b2的f1方法可以弹出"p2 value"的提示信息。尽管b2对象已经包含了p2属性值,但拷贝后该属性值会被覆盖。可以在调用apply方法时,在第三个参数中指定拷贝属性的默认值,比如下面的代码:


PLAIN TEXT


 


 

Ext.apply(b2, b1, { p3: "p3 value" });
alert(b2.p3);

 


这样会使得b2中包含一个p3的属*,值为"p3 value"。
applyIf方法的功能跟apply一样,只是不会拷贝那些在目标对象及源对象都存在的属性。比如把前面演示apply方法的代码改成applyIf,如下:


PLAIN TEXT


 


 

Ext.applyIf(b2, b1);
b2.f1();

 


由于b2中已经存在了p2属*,因此,b2.f1()方法中引用this.p2的时候,得到的是"b2 value",而不是在b1中定义的"p2 value"。

抱歉!评论已关闭.