Js用法中还有个极好的但是有些抽象的用法——call与apply,今天我要简单总结一下:

 var ob1={  //对象ob1
name:"ob1",
func1:function(a,b,c){
alert(this.name+a+b+c);
}
} var ob2={ //对象ob2
name:"ob2",
func2:function(){
alert(this.name);
}
}
ob1.func1.call(ob2,"1","2","3"); //ob1123,call让对象b调用了a的func1,把指向a的指针指向了b,让b可以通过a的func1的写法访问到自己的属性
ob2.func2.call(ob1); //ob1
ob1.func1.apply(ob2,[1,2,3]); //ob2123
ob2.func2.apply(ob1); //ob1

    "ob2.func2.call(ob1)"等价于"ob1.func2()",事实上ob1并没有fun2,但是call可以帮他从ob2那儿借来并且指针指向ob1,func2中的this指向了它的调用者ob1,输出ob1的name属性。apply与call用法一样,但是参数传递的方式不同。

你可能会觉得有点绕,怀疑这样写的方便性在哪儿。我们来简单粗略地总结一下它该何时用,当对象2想要调用对象1中的方法,以便少写代码时,一般此时对象1与对象2具有相似的属性,类型相近或者相同。

04-28 10:55