码迷,mamicode.com
首页 > 移动开发 > 详细

call与apply基础用法告诉你

时间:2016-03-19 14:41:46      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:

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

          

      

call与apply基础用法告诉你

标签:

原文地址:http://www.cnblogs.com/zhu-xingyu/p/5295031.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!