成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

JavaScript 中this在不同調(diào)用模式中的差異

wuyangnju / 1106人閱讀

摘要:的值為以此模式調(diào)用函數(shù)時(shí),被綁定到全局對(duì)象。在傳統(tǒng)的面向類的語言中,構(gòu)造函數(shù)是類中的一些特殊方法,使用初始化類時(shí)會(huì)調(diào)用類中的構(gòu)造函數(shù)。包括內(nèi)置對(duì)象函數(shù)在內(nèi)的所有函數(shù)都可以用來調(diào)用,這種函數(shù)調(diào)用被稱為構(gòu)造函數(shù)調(diào)用。

調(diào)用一個(gè)函數(shù)會(huì)暫停當(dāng)前函數(shù)的執(zhí)行,傳遞控制權(quán)和參數(shù)給新函數(shù)。除了聲明時(shí)定義的形式參數(shù),每個(gè)函數(shù)還接受兩個(gè)附加參數(shù): this 和 arguments。參數(shù) this 的值取決于調(diào)用的模式。在JavaScript中一共有4中調(diào)用模式: 方法調(diào)用模式、函數(shù)調(diào)用模式、構(gòu)造器調(diào)用模式和 apply 調(diào)用模式。

方法調(diào)用模式(隱式綁定)

當(dāng)一個(gè)函數(shù)被保存為對(duì)象的一個(gè)屬性時(shí),我們稱它為一個(gè)方法。當(dāng)一個(gè)方法被調(diào)用時(shí),this 被綁定到該對(duì)象。如果調(diào)用表達(dá)式包含一個(gè)提取屬性的動(dòng)作(即包含一個(gè) .點(diǎn)表達(dá)式或[subscript]下標(biāo)表達(dá)式),那么它就是被當(dāng)做一個(gè)方法來調(diào)用。

// 創(chuàng)建 myObject 對(duì)象,有一個(gè) value 屬性和一個(gè) increment 方法
// increment 方法接受一個(gè)可選的參數(shù)。如果參數(shù)不是數(shù)字,那么默認(rèn)使用數(shù)字1

var myObject = {
    value: 0,
    increment: function (inc){
        this.value += typeof inc === "number" ? inc : 1;
    }
};

myObject.increment();
document.writeln(myObject.value);   // 1

myObject.increment(2);
document.writeln(myObject.value);   // 3

方法可以使用 this 訪問自己所屬的對(duì)象,所以它能從對(duì)象中取值貨對(duì)對(duì)象進(jìn)行修改。 this 到對(duì)象的綁定發(fā)生在調(diào)用的時(shí)候。

函數(shù)調(diào)用模式(默認(rèn)綁定)

當(dāng)一個(gè)函數(shù)并非一個(gè)對(duì)象的屬性時(shí),它就是被當(dāng)做一個(gè)函數(shù)來調(diào)用的。

var sum = add(3,4);   // sum 的值為7

以此模式調(diào)用函數(shù)時(shí),this 被綁定到全局對(duì)象。這是語言設(shè)計(jì)上的一個(gè)錯(cuò)誤。若正確,那么當(dāng)內(nèi)部函數(shù)被調(diào)用時(shí),this 應(yīng)該仍然綁定到外部函數(shù)的 this 變量。這樣設(shè)計(jì)的后果就是方法不能利用內(nèi)部函數(shù)來幫助它工作,因?yàn)閮?nèi)部函數(shù)的 this 被綁定了錯(cuò)誤的值,不能共享該方法對(duì)對(duì)象的訪問權(quán)。

解決方案: 如果該方法定義一個(gè)便令并給它賦值為 this,那么內(nèi)部函數(shù)就可以通過那個(gè)變量訪問到 this。按照約定,把那個(gè)變量命名為 that:

// 給 myObject 增加一個(gè) double 方法

myObject.double = function () {
    var that = this;   // 解決方法
    
    var helper = function () {
        that.value = add(that.value, that.value);
    };
    
    helper();   // 以函數(shù)的形式調(diào)用helper
};

// 以方法的形式調(diào)用 double

myObject.double();
document.writeln(myObject.value);   // 6

如果使用嚴(yán)格模式(strict mode),那么全局對(duì)象無法使用默認(rèn)綁定,this 會(huì)綁定到undefined

function foo() {
    "use strict";
    
    console.log(this.a);
}

var a = 2;

foo();   // TypeError: this is undefined

這里有一個(gè)微妙但是非常中亞偶的細(xì)節(jié),雖然 this 的綁定規(guī)則完全取決于調(diào)用位置,但是只有 foo() 運(yùn)行在非 strict mode 下時(shí),默認(rèn)綁定才能綁定到全局對(duì)象;嚴(yán)格模式下與 foo() 的調(diào)用位置無關(guān):

function foo() {
    console.log(this.a);
}

var a = 2;

(function(){
    "use strict";
    
    foo();   // 2
})();
構(gòu)造器調(diào)用模式

如果在一個(gè)函數(shù)前面帶上 new 來調(diào)用,那么背地里將會(huì)創(chuàng)建一個(gè)連接到該函數(shù)的 prototype 成員的新對(duì)象,同時(shí) this 會(huì)被綁定到那個(gè)新對(duì)象上。

首先,我們來了解一下構(gòu)造函數(shù)。在傳統(tǒng)的面向類的語言中,“構(gòu)造函數(shù)”是類中的一些特殊方法,使用 new 初始化類時(shí)會(huì)調(diào)用類中的構(gòu)造函數(shù)。通常的形式為:

something = new MyClass(..);

JavaScript也有一個(gè) new 操作符,使用方法看起來和那些面向類的語言一樣,但 JavaScript 中的 new 機(jī)制實(shí)際上和面向類語言完全不同。
在 JavaScript 中,構(gòu)造函數(shù)只是一些使用 new 操作符時(shí)被調(diào)用的函數(shù)。它們不屬于某個(gè)類,也不會(huì)實(shí)例化一個(gè)類。實(shí)際上,它們甚至都不能說是一種特殊的函數(shù)類型,它們只是被 new 操作符調(diào)用的普通函數(shù)而已。包括內(nèi)置對(duì)象函數(shù)在內(nèi)的所有函數(shù)都可以用 new 來調(diào)用,這種函數(shù)調(diào)用被稱為構(gòu)造函數(shù)調(diào)用。實(shí)際上并不存在所謂的構(gòu)造函數(shù),只有對(duì)于函數(shù)的構(gòu)造調(diào)用。
使用 new 來調(diào)用函數(shù),會(huì)自動(dòng)執(zhí)行以下操作:

創(chuàng)建(或者說構(gòu)造)一個(gè)全新的對(duì)象。

這個(gè)新對(duì)象會(huì)被執(zhí)行[[原型]]連接

這個(gè)新對(duì)象會(huì)綁定到函數(shù)調(diào)用的 this

如果函數(shù)沒有返回其他對(duì)象,那么 new 表達(dá)式中的函數(shù)會(huì)自動(dòng)返回這個(gè)新對(duì)象

// 創(chuàng)建一個(gè)名為 Quo 構(gòu)造器函數(shù)。它構(gòu)造一個(gè)帶有 status 屬性的對(duì)象

var Quo = function (string) {
    this.status = string;
};

// 給 Quo 的所有實(shí)例提供一個(gè)名為 get_status 的公共方法

Quo.prototype.get_status = function () {
    return this.status;
};

// 構(gòu)造一個(gè) Quo 實(shí)例

var myQuo = new Quo("confused");
document.writeln(myQuo.get_status());   // confused
Apply 調(diào)用模式

apply 方法讓我們構(gòu)建一個(gè)參數(shù)數(shù)組傳遞給調(diào)用函數(shù),也允許我們選擇 this 的值。apply 方法接收兩個(gè)參數(shù),第一個(gè)是要綁定給 this 的值,第二個(gè)就是一個(gè)參數(shù)數(shù)組。

// 構(gòu)造一個(gè)包含兩個(gè)數(shù)字的數(shù)組,并將它們相加

var array = [3,4];
var sum = add.apply(null,array);   // 7

// 構(gòu)造一個(gè)包含 status 成員的對(duì)象

var statusObject = {
    status: "A-OK";
};

// statusObject 并沒有繼承自 Quo.prototype,但我們可以在 statusObject 上調(diào)用 get_statuse 方法,盡管statusObject 并沒有一個(gè)名為 get_status 的方法

var status = Quo.prototype.get_status.apply(statusObject);   // A-OK

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/80289.html

相關(guān)文章

  • JavaScript this 講解

    摘要:作為方法進(jìn)行調(diào)用,該上下文是方法的擁有者作為全局函數(shù)調(diào)用,其上下文永遠(yuǎn)是也就是說,該函數(shù)是的一個(gè)方法作為構(gòu)造器進(jìn)行調(diào)用時(shí),其上下文對(duì)象則是新創(chuàng)建的對(duì)象實(shí)例。 精確把握 JavaScript 中的 this this 是 JavaScript 中的一個(gè)關(guān)鍵字,當(dāng)一個(gè)函數(shù)被調(diào)用時(shí),除了傳入函數(shù)的顯式參數(shù)以外,名為 this 的隱式參數(shù)也被傳入了函數(shù)。this 參數(shù)指向了一個(gè)自動(dòng)生成的內(nèi)部對(duì)...

    zhangwang 評(píng)論0 收藏0
  • 功能性組件和Classes有什么不同?

    摘要:函數(shù)組件與類有何不同有一段時(shí)間,規(guī)范的答案是類可以訪問更多功能如狀態(tài)。那么功能性函數(shù)和類是否又根本的區(qū)別函數(shù)組件捕獲的值。假設(shè)功能組件不存在。在我到目前為止看到的所有情況中,由于錯(cuò)誤地假設(shè)功能不會(huì)改變或總是相同,所以會(huì)出現(xiàn)陳舊的封閉問題。 React函數(shù)組件與React類有何不同? 有一段時(shí)間,規(guī)范的答案是類可以訪問更多功能(如狀態(tài))。但是自從有了Hook后,這個(gè)答案變得不唯一了。 也...

    lmxdawn 評(píng)論0 收藏0
  • 功能性組件和Classes有什么不同

    摘要:函數(shù)組件與類有何不同有一段時(shí)間,規(guī)范的答案是類可以訪問更多功能如狀態(tài)。那么功能性函數(shù)和類是否又根本的區(qū)別函數(shù)組件捕獲的值。假設(shè)功能組件不存在。在我到目前為止看到的所有情況中,由于錯(cuò)誤地假設(shè)功能不會(huì)改變或總是相同,所以會(huì)出現(xiàn)陳舊的封閉問題。 React函數(shù)組件與React類有何不同? 有一段時(shí)間,規(guī)范的答案是類可以訪問更多功能(如狀態(tài))。但是自從有了Hook后,這個(gè)答案變得不唯一了。 也...

    GitCafe 評(píng)論0 收藏0
  • 功能性組件和Classes有什么不同?

    摘要:函數(shù)組件與類有何不同有一段時(shí)間,規(guī)范的答案是類可以訪問更多功能如狀態(tài)。那么功能性函數(shù)和類是否又根本的區(qū)別函數(shù)組件捕獲的值。假設(shè)功能組件不存在。在我到目前為止看到的所有情況中,由于錯(cuò)誤地假設(shè)功能不會(huì)改變或總是相同,所以會(huì)出現(xiàn)陳舊的封閉問題。 React函數(shù)組件與React類有何不同? 有一段時(shí)間,規(guī)范的答案是類可以訪問更多功能(如狀態(tài))。但是自從有了Hook后,這個(gè)答案變得不唯一了。 也...

    peixn 評(píng)論0 收藏0
  • 設(shè)計(jì)模式——工廠模式

    摘要:簡(jiǎn)單工廠模式創(chuàng)建單一的對(duì)象示例描述工廠模式主要是為了創(chuàng)建對(duì)象實(shí)例或者類簇抽象工廠關(guān)心的是最終產(chǎn)出創(chuàng)建的對(duì)象而不關(guān)心創(chuàng)建的過程在出現(xiàn)多個(gè)類的時(shí)候每次創(chuàng)建需要找到對(duì)應(yīng)的類往往比較麻煩這時(shí)候通常使用一個(gè)函數(shù)進(jìn)行封裝來創(chuàng)建所需要的對(duì)象這樣就無需關(guān)注 簡(jiǎn)單工廠模式(創(chuàng)建單一的對(duì)象) 示例1 描述 工廠模式主要是為了創(chuàng)建對(duì)象實(shí)例或者類簇(抽象工廠), 關(guān)心的是最終產(chǎn)出(創(chuàng)建)的對(duì)象, 而不關(guān)心創(chuàng)建...

    Moxmi 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<