JavaScript之Function的apply与call

无意中翻到的一篇文章

http://xiaolincc26201206092327.iteye.com/blog/2213367


JavaScript函数调用分为4中模式:

1. 方法调用模式:即对象包含方法属性,Obj.methodName()或者Obj[methodName]()

2. 函数调用模式:即methodName()

3. 构造器调用模式:即new MethodName()

4. applycall调用模式:即ObjA.apply(ObjB,args[])或者ObjA.call(ObjB,arg1,arg2...)

函数调用时,除了接收形式参数外,还会接收thisarguments。其中this为函数对象上下文,arguments为实际参数。

applycall实现同样的功能,即切换函数对象的上下文(this指向的引用),区别在于形式参数不一样。applyarguments或者数组,call为以逗号隔开多个单独形式参数。

  1. <span style="font-size: 16px;">function add(c)  
  2. {  
  3.    alert(this.a+this.b+c);  
  4. }  
  5. var test={a:1,b:2}  
  6. add.call(test,3); </span>  


在执行add.call(test,3); 之前add和test都属于window下,此时this指向window。add.call(test,3); 执行时,进入add方法体,此时this由window切换为test,此时this.a=test.a,this.b=test.b,c为形式参数传入的值,即alert()的结果为1+2+3=6。apply也是一样的功能。

 

通过apply和call实现扩展和继承:

  1. <span style="font-size: 12px;"function Animal(name){      
  2.      this.name = name;      
  3.      this.showName = function(){      
  4.          alert(this.name);      
  5.      }      
  6.  }      
  7.      
  8.  function Cat(name){    
  9.      Animal.call(this, name);  
  10.  }      
  11.      
  12.  var cat = new Cat("Black Cat");//执行时,Cat函数体的this由window切换为Cat{},  
  13. // Animal函数体的this.name通过形式参数传入即为Black Cat,最终cat  
  14.  //得到的结果为cat=Cat{name:"Black Cat",showName: function(){ alert(this.name);},  
  15.  cat.showName();//执行时this由window切换为  
  16.  //Cat{name:"Black Cat",showName: function(){ alert(this.name);} 此时this.name  
  17.  //为this.name=Cat.name,因此为Black Cat。</span>  



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值