首頁 > web前端 > js教程 > 主體

JavaScript中兩個非繼承方法用法實例詳解

伊谢尔伦
發布: 2017-07-20 14:52:03
原創
1030 人瀏覽過

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);
登入後複製

以上是JavaScript中兩個非繼承方法用法實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!