首頁 >web前端 >js教程 >在JavaScript中call()與apply()區別_javascript技巧

在JavaScript中call()與apply()區別_javascript技巧

WBOY
WBOY原創
2016-05-16 15:18:431124瀏覽

如果沒接觸過動態語言,以編譯型語言的思維方式去理解javaScript將會有種神奇而怪異的感覺,因為意識上往往不可能的事偏偏就發生了,甚至覺得不可理喻.如果在學JavaScript這自由而變幻無窮的語言過程中遇到這種感覺,那麼就從現在形始,請放下的您的」偏見」,因為這對您來說絕對是一片新大陸,讓JavaScrip

好,言歸正傳,先理解JavaScrtipt動態變換運行時上下文特性,這種特性主要就體現在apply, call兩個方法的運用上.

一、方法的定義

call方法:

語法:call(thisObj,Object)

定義:呼叫一個物件的一個方法,以另一個物件取代目前物件。

說明:

call 方法可以用來取代另一個物件呼叫一個方法。 call 方法可將一個函數的物件上下文從初始的上下文變更為由 thisObj 指定的新物件。
如果沒有提供 thisObj 參數,那麼 Global 物件被用作 thisObj。

apply方法:

文法:apply(thisObj,[argArray])

定義:應用某一物件的一個方法,用另一個物件取代目前物件。

說明:

如果 argArray 不是一個有效的陣列或不是 arguments 對象,那麼將導致一個 TypeError。

如果沒有提供 argArray 和 thisObj 任何一個參數,那麼 Global 物件將被用作 thisObj, 並且無法被傳遞任何參數。

----------------------------------------------- ---------------------------------

注意:call和apply方法完全一致,只是apply在傳參的方式上,它以數組方式來傳參。

程式碼範例:

function Animal(name) {
this.name = name;
this.showName = function() {
console.log(this.name);
};
}
function Cat(name) {
Animal.call(this, name);
}
Cat.prototype = new Animal();
function Dog(name) {
Animal.apply(this, name);
}
Dog.prototype = new Animal();
var cat = new Cat("Black Cat"); //call必须是object
var dog = new Dog(["Black Dog"]); //apply必须是array
cat.showName();
dog.showName();
console.log(cat instanceof Animal);
console.log(dog instanceof Animal); 

----------------------------------------------- --------------------------------

模擬call, apply的this替換

function Animal(name) {
this.name = name;
this.showName = function() {
alert(this.name);
};
};
function Cat(name) {
this.superClass = Animal;
this.superClass(name);
delete superClass;
}
var cat = new Cat("Black Cat");
cat.showName();

總結:

它們各自的定義:

apply:應用某一物件的一個方法,用另一個物件取代目前物件。

call:呼叫一個物件的一個方法,以另一個物件取代目前物件。

它們的共同點:

都「可以用來取代另一個物件呼叫一個方法,將一個函數的物件上下文從初始的上下文改變為由 thisObj 指定的新物件。」—摘自JScript5.5 .chm

它們的差異:

apply:最多只能有兩個參數-新this物件和一個陣列 argArray。如果給該方法傳遞多個參數,則把參數都寫進這個數組裡面,當然,即使只有一個參數,也要寫進數組裡面。如果 argArray 不是一個有效的陣列或不是 arguments 對象,那麼將導致一個 TypeError。如果沒有提供 argArray 和 thisObj 任何一個參數,那麼 Global 物件將被用作 thisObj, 並且無法被傳遞任何參數。

call:則是直接的參數列表,主要用在js物件各方法互相調用的時候,使當前this實例指針保持一致,或在特殊情況下需要改變this指針。如果沒有提供 thisObj 參數,那麼 Global 物件被用作 thisObj。

更簡單地說,apply和call功能一樣,只是傳入的參數列表形式不同:如func.call(func1,var1,var2,var3)對應的apply寫法為:func.apply(func1,[var1 ,var2,var3])

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn