在JavaScript中call()與apply()區(qū)別
如果沒接觸過動態(tài)語言,以編譯型語言的思維方式去理解javaScript將會有種神奇而怪異的感覺,因為意識上往往不可能的事偏偏就發(fā)生了,甚至覺得不可理喻.如果在學JavaScript這自由而變幻無窮的語言過程中遇到這種感覺,那么就從現(xiàn)在形始,請放下的您的”偏見”,因為這對您來說絕對是一片新大陸,讓JavaScrip
好,言歸正傳,先理解JavaScrtipt動態(tài)變換運行時上下文特性,這種特性主要就體現(xiàn)在apply, call兩個方法的運用上.
一、方法的定義
call方法:
語法:call(thisObj,Object)
定義:調用一個對象的一個方法,以另一個對象替換當前對象。
說明:
call 方法可以用來代替另一個對象調用一個方法。call 方法可將一個函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象。
如果沒有提供 thisObj 參數(shù),那么 Global 對象被用作 thisObj。
apply方法:
語法:apply(thisObj,[argArray])
定義:應用某一對象的一個方法,用另一個對象替換當前對象。
說明:
如果 argArray 不是一個有效的數(shù)組或者不是 arguments 對象,那么將導致一個 TypeError。
如果沒有提供 argArray 和 thisObj 任何一個參數(shù),那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數(shù)。
--------------------------------------------------------------------------------
注意:call和apply方法完全一致,只是apply在傳參的方式上,它以數(shù)組方式來傳參。
代碼示例:
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:調用一個對象的一個方法,以另一個對象替換當前對象。
它們的共同之處:
都“可以用來代替另一個對象調用一個方法,將一個函數(shù)的對象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對象。”——摘自JScript5.5 .chm
它們的不同之處:
apply:最多只能有兩個參數(shù)——新this對象和一個數(shù)組 argArray。如果給該方法傳遞多個參數(shù),則把參數(shù)都寫進這個數(shù)組里面,當然,即使只有一個參數(shù),也要寫進數(shù)組里面。如果 argArray 不是一個有效的數(shù)組或者不是 arguments 對象,那么將導致一個 TypeError。如果沒有提供 argArray 和 thisObj 任何一個參數(shù),那么 Global 對象將被用作 thisObj, 并且無法被傳遞任何參數(shù)。
call:則是直接的參數(shù)列表,主要用在js對象各方法互相調用的時候,使當前this實例指針保持一致,或在特殊情況下需要改變this指針。如果沒有提供 thisObj 參數(shù),那么 Global 對象被用作 thisObj。
更簡單地說,apply和call功能一樣,只是傳入的參數(shù)列表形式不同:如 func.call(func1,var1,var2,var3)對應的apply寫法為:func.apply(func1,[var1,var2,var3])
- JavaScript中的apply()方法和call()方法使用介紹
- JS面向對象、prototype、call()、apply()
- 跟我學習javascript的call(),apply(),bind()與回調
- js繼承call()和apply()方法總結
- js中apply()和call()的區(qū)別與用法實例分析
- 基于JavaScript實現(xiàn)繼承機制之調用call()與apply()的方法詳解
- 深入理解關于javascript中apply()和call()方法的區(qū)別
- 淺談javascript的call()、apply()、bind()的用法
- 有關JavaScript中call()和apply() 的一些理解
- JavaScript函數(shù)apply()和call()用法與異同分析
- JS中call()和apply()的功能及用法實例分析
相關文章
JavaScript遍歷table表格中的某行某列并打印其值
這篇文章主要介紹了JavaScript遍歷table表格中的某行某列并打印其值,需要的朋友可以參考下2014-07-07javascript面向對象之共享成員屬性與方法及prototype關鍵字用法
這篇文章主要介紹了javascript面向對象之共享成員屬性與方法及prototype關鍵字用法,實例分析了prototype關鍵字在共享成員屬性與方法中的原理與使用技巧,需要的朋友可以參考下2015-01-01