首頁  >  文章  >  web前端  >  JavaScript中的apply()方法和call()方法使用介紹_javascript技巧

JavaScript中的apply()方法和call()方法使用介紹_javascript技巧

WBOY
WBOY原創
2016-05-16 17:51:431093瀏覽

1.每個函數都包含兩個非繼承而來的方法:apply()和call()。
2、他們的用途相同,都是在特定的作用域中呼叫函數。
3.接收參數方面不同,apply()接收兩個參數,一個是函數運作的作用域(this),另一個是參數陣列。
call()方法第一個參數與apply()方法相同,但傳遞給函數的參數必須列舉出來。
  例1:

複製程式碼 程式碼如下:


程式碼如下:

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