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具有相似的属性,类型相近或者相同。