Ext-base.js开头有这样一个方法apply。
代码如下:
Ext.apply=function (C,D,B){
if(B){
Ext.apply(C,B);
}
if(C&&D&&typeof D=="object"){
for(var A in D){
C[A]=D[A];
}
}
return C;
};
该段代码的作用是实现对象的继承。
参数意义:
如果只传入两个参数,则将C继承D的所有方法属性,如果定义了B则每次都先继承B的方法属性然后再继承D的方法属性,即B是默认继承对象。
代码不难理解,之后自己思虑写一个可以继承无限对象的方法,及可以传入n个对象,然后将所有对象的方法属性继承给第一个参数对象并返回该对象。花了几分钟写出了一个(代码没有做优化)。
代码如下:
<script type="text/javascript">
<!--
function apply(){
var l=arguments.length;
if(l<1)return null; //无参数
if(l>2){ //多于两个
apply(arguments[0],arguments[l-1]); //从最后一个开始继承
arguments.length=l-1; //去掉最后一个参数然后递归
apply(arguments);
}
//两个参数
if(arguments[0]&&arguments[1]&&typeof arguments[1]=="object"){
for(var A in arguments[1]){
arguments[0][A]=arguments[1][A];
}
}
return arguments[0];
};
var a=new Object();
a.a="xxx";
a.e="yyy";
a.f="zzz";
var b={xx:"aaaa",yy:"dsdfa",tt:"ddddd"};
var d={s1:"tesas",s2:"545465"};
var c=new Object();
var obj=apply(a,b,c,d);
for(var i in obj){
alert(i+":"+obj);
}
//-->
</script>
From: http://tb.blog.csdn.net/TrackBack.aspx?PostId=2152171
代码如下:
Ext.apply=function (C,D,B){
if(B){
Ext.apply(C,B);
}
if(C&&D&&typeof D=="object"){
for(var A in D){
C[A]=D[A];
}
}
return C;
};
该段代码的作用是实现对象的继承。
参数意义:
如果只传入两个参数,则将C继承D的所有方法属性,如果定义了B则每次都先继承B的方法属性然后再继承D的方法属性,即B是默认继承对象。
代码不难理解,之后自己思虑写一个可以继承无限对象的方法,及可以传入n个对象,然后将所有对象的方法属性继承给第一个参数对象并返回该对象。花了几分钟写出了一个(代码没有做优化)。
代码如下:
<script type="text/javascript">
<!--
function apply(){
var l=arguments.length;
if(l<1)return null; //无参数
if(l>2){ //多于两个
apply(arguments[0],arguments[l-1]); //从最后一个开始继承
arguments.length=l-1; //去掉最后一个参数然后递归
apply(arguments);
}
//两个参数
if(arguments[0]&&arguments[1]&&typeof arguments[1]=="object"){
for(var A in arguments[1]){
arguments[0][A]=arguments[1][A];
}
}
return arguments[0];
};
var a=new Object();
a.a="xxx";
a.e="yyy";
a.f="zzz";
var b={xx:"aaaa",yy:"dsdfa",tt:"ddddd"};
var d={s1:"tesas",s2:"545465"};
var c=new Object();
var obj=apply(a,b,c,d);
for(var i in obj){
alert(i+":"+obj);
}
//-->
</script>
From: http://tb.blog.csdn.net/TrackBack.aspx?PostId=2152171