extjs中apply和applyIf

本文详细解释了Ext.js库中的apply和applyIf方法的使用方式、参数说明和示例应用,帮助开发者更好地掌握这两个方法的区别与用法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

apply

 

 

方法的签名

 

apply( Object obj, Object config, Object defaults ) : Object

 

参数说明

 

第一个参数是要复制的目标对象;第二个参数是复制的源对象;第三个参数是默认源对象,第三个参数是可选的,意味着如果第三个参数有值,则将第三个参数也复制到目标对象中

 

apply实例

 

下面的代码中,Ext.apply(b2,b1)这一语句把b1的属性拷贝到了b2对象中,因此调用b2的f1方法可以弹出"p2 value"的提示信息。尽管b2对象已经包含了p2属性值,但拷贝后该属性值会被覆盖。
 
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();
 
 

applyIf

 

 

功能跟apply一样,只是不会拷贝那些在目标对象及源对象都存在的属性。

 

 

applyIf实例:

比如把前面演示apply方法的代码改成applyIf,如下:

 

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

 

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

 

 

 

 

参考资料:      extjs中apply和applyIf的用法       http://www.studyofnet.com/news/192.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值