js 中的call apply

Posted ls-lansy

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js 中的call apply相关的知识,希望对你有一定的参考价值。


javascript OOP中,我们经常会这样定义:
function cat(){
}
cat.prototype={
food:"fish",
say: function(){
alert("I love "+this.food);
}
}


var blackCat = new cat;
blackCat.say();

但是如果我们有一个对象whiteDog = {food:"bone"},我们不想对它重新定义say方法,那么我们可以通过call或apply用blackCat的say方法:blackCat.say.call(whiteDog);

所以,可以看出call和apply是为了动态改变this而出现的,当一个object没有某个方法,但是其他的有,我们可以借助call或apply用其它对象的方法来操作。

用的比较多的,通过document.getElementsByTagName选择的dom 节点是一种类似array的array。它不能应用Array下的push,pop等方法。我们可以通过:
var domNodes = Array.prototype.slice.call(document.getElementsByTagName("*"));
这样domNodes就可以应用Array下的所有方法了。

1.call()

语法:obj1.call(obj2[,param1,param2,...])
定义:用obj2对象来代替obj1,调用obj1的方法。即将obj1应用到obj2上。
说明:call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 obj2 指定的新对象。 如果没有提供 obj2参数,那么 Global 对象被用作 obj2。

2.apply()

语法:obj1.call(obj2[,arrArg])
定义:用obj2对象来代替obj1,调用obj1的方法。即将obj1应用到obj2上。
说明:call ()和apply()作用一样,但是call()可以接收任何类型的参数,而apply()只能接收数组参数。

3.基本用法

[javascript] view plain copy
 
  1. function add(a,b){  
  2.     return a+b;  
  3. }  
  4. function sub(c,d){  
  5.     return c-d;  
  6. }  
  7. function result(){  
  8.     this.addValue = null;  
  9.     this.subValue = null;  
  10.     this.showResult=function(){  
  11.         alert(this.addValue);  
  12.         alert(this.subValue);  
  13.     }  
  14. }  
  15. var r = new result();  
  16. r.addValue = add.call(sub,4,2); //6,将add方法应用到sub上,即sub的指针指向add方法  
  17. r.subValue = sub.call(add,4,2); //2,用add对象替换sub对象,并调用sub对象的方法  
  18. r.showResult(); //在js中函数也是一个Function对象,函数名即是对象引用  

4.继承特性

[javascript] view plain copy
 
  1. function add(a,b){  
  2.     return a+b;  
  3. }  
  4. function sub(c,d){  
  5.     return c-d;  
  6. }  
  7. function result(){  
  8.     this.addValue = null;  
  9.     this.subValue = null;  
  10.     this.showResult=function(){  
  11.         alert(this.addValue);  
  12.         alert(this.subValue);  
  13.     }  
  14. }  
  15. var r = new result();  
  16. r.addValue = add.call(r,4,2);   //6,r继承add函数的所有特性  
  17. r.subValue = sub.call(r,4,2);   //2,r集成sub函数的所有特性  
  18. r.showResult();   


















以上是关于js 中的call apply的主要内容,如果未能解决你的问题,请参考以下文章

JS中的call()和apply()方法

JS中的call,apply和bind及记忆方式

js插件进阶JS中的call()和apply()方法详解

JS中的call()和apply()方法

js中的apply,call,arguments,callee,caller详解

JS中的call()和apply()方法