標籤:
原文連結 http://www.jb51.net/article/30883.htm
想要理解透徹apply()和call() ,還要需要理解this 範圍 局部變數 全域變數
js apply()和call()
1、每個函數都包含兩個非繼承而來的方法:apply()和call()。 2、他們的用途相同,都是在特定的範圍中調用函數。 3、接收參數方式不同
apply()接收兩個參數,一個是函數啟動並執行範圍(this),另一個是參數數組。 call()方法第一個參數與apply()方法相同,但傳遞給函數的參數必須列舉出來。
例1:複製代碼 代碼如下:window.firstName = "diz"; window.lastName = "song"; var myObject = { firstName: "my", lastName: "Object" }; function HelloName() { console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!"); } HelloName.call(window); //huo .call(this); HelloName.call(myObject); 運行結果為: Hello diz song glad to meet you! Hello my Object glad to meet you!
例2: 複製代碼 代碼如下:function sum(num1, num2) { return num1 + num2; } console.log(sum.call(window, 10, 10)); //20 console.log(sum.apply(window,[10,20])); //30 分析:在例1中,我們發現apply()和call()的真正用武之地是能夠擴充函數賴以啟動並執行範圍
如果我們想用傳統的方法實現,請見下面的代碼:
window.firstName = "diz"; window.lastName = "song"; var myObject = { firstName: "my", lastName: "Object" }; function HelloName() { console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!"); } HelloName(); //Hello diz song glad to meet you! myObject.HelloName = HelloName; myObject.HelloName(); //Hello my Object glad to meet you!
見加紅的代碼,我們發現,要想讓HelloName()函數的範圍在對象myObject上,我們需要動態建立myObject的HelloName屬性,此屬性作為指標指向HelloName()函數,這樣,當我們調用myObject.HelloName()時,函數內部的this變數就指向myObjecct,也就可以調用該對象的內部其他公用屬性了。 通過分析例2,我們可以看到call()和apply()函數的真正運用之處,在實際項目中,還需要根據實際靈活加以處理! 一個小問題:再看一看函數中定義函數時,this變數的情況 複製代碼 代碼如下:function temp1() { console.log(this); //Object {} function temp2() { console.log(this); //Window } temp2(); } var Obj = {}; temp1.call(Obj); //運行結果見上面綠色的注釋!!!!執行結果與下面的相同: 複製代碼 代碼如下:function temp1() { console.log(this); temp2(); } function temp2() { console.log(this); } var Obj = {}; temp1.call(Obj); 4、bind()方法 支援此方法的瀏覽器有IE9+、Firefox4+、Safari5.1+、Opera12+、Chrome。它是屬於ECMAScript5的方法。直接看例子:複製代碼 代碼如下:window.color = "red"; var o = { color: "blue" }; function sayColor(){ alert(this.color); } var OSayColor = sayColor.bind(o); OSayColor(); //blue 這裡,sayColor()調用bind()方法,並傳入o對象,返回了OSayColor()函數,在OSayColor()中,this的值就為o對象。
javascript apply()和call()