轉(zhuǎn) http://www.cnitblog.com/yemoo/archive/2007/11/30/37070.html
JavaScript中有一個(gè)call和apply方法,其作用基本相同,但也有略微的區(qū)別。
先來看看JS手冊中對call的解釋:
call 方法
調(diào)用一個(gè)對象的一個(gè)方法,以另一個(gè)對象替換當(dāng)前對象。
call([thisObj[,arg1[, arg2[, [,.argN]]]]])
參數(shù)
thisObj
可選項(xiàng)。將被用作當(dāng)前對象的對象。
arg1, arg2, , argN
可選項(xiàng)。將被傳遞方法參數(shù)序列。
說明
call 方法可以用來代替另一個(gè)對象調(diào)用一個(gè)方法。call 方法可將一個(gè)函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象。
如果沒有提供 thisObj 參數(shù),那么 Global 對象被用作 thisObj。
說明白一點(diǎn)其實(shí)就是更改對象的內(nèi)部指針,即改變對象的this指向的內(nèi)容。這在面向?qū)ο蟮膉s編程過程中有時(shí)是很有用的。
引用網(wǎng)上一個(gè)代碼段,運(yùn)行后自然就明白其道理。
<input type="text" id="myText" value="input text">
<script>
function Obj(){this.value="對象!";}
var value="global 變量";
function Fun1(){alert(this.value);}
window.Fun1(); //global 變量
Fun1.call(window); //global 變量
Fun1.call(document.getElementById('myText')); //input text
Fun1.call(new Obj()); //對象!
</script>
call函數(shù)和apply方法的第一個(gè)參數(shù)都是要傳入給當(dāng)前對象的對象,及函數(shù)內(nèi)部的this。后面的參數(shù)都是傳遞給當(dāng)前對象的參數(shù)。
運(yùn)行如下代碼:
<script>
var func=new function(){this.a="func"}
var myfunc=function(x){
var a="myfunc";
alert(this.a);
alert(x);
}
myfunc.call(func,"var");
</script>
可見分別彈出了func和var。到這里就對call的每個(gè)參數(shù)的意義有所了解了。
對于apply和call兩者在作用上是相同的,但兩者在參數(shù)上有區(qū)別的。
對于第一個(gè)參數(shù)意義都一樣,但對第二個(gè)參數(shù):
apply傳入的是一個(gè)參數(shù)數(shù)組,也就是將多個(gè)參數(shù)組合成為一個(gè)數(shù)組傳入,而call則作為call的參數(shù)傳入(從第二個(gè)參數(shù)開始)。
如 func.call(func1,var1,var2,var3)對應(yīng)的apply寫法為:func.apply(func1,[var1,var2,var3])
同時(shí)使用apply的好處是可以直接將當(dāng)前函數(shù)的arguments對象作為apply的第二個(gè)參數(shù)傳入