欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js this 綁定機制深入詳解

 更新時間:2020年04月30日 08:33:40   作者:廖飛銀  
這篇文章主要介紹了js this 綁定機制,結合實例形式深入分析了js this 綁定機制相關原理、使用技巧與操作注意事項,需要的朋友可以參考下

本文實例講述了js this 綁定機制。分享給大家供大家參考,具體如下:

函數(shù)調(diào)用位置

與詞法作用域相反的是,this的指向由函數(shù)運行時決定,它是動態(tài)的,隨著函數(shù)調(diào)用位置變化而變化。

要理解 this,首先要理解調(diào)用位置:調(diào)用位置就是函數(shù)在代碼中被調(diào)用的位置(而不是聲明的位置)。只有仔細分析調(diào)用位置才能回答這個問題:這個this到底引用的是什么?

function baz() {
// 當前調(diào)用棧是:baz
// 因此,當前調(diào)用位置是全局作用域
console.log( "baz" );
bar(); // <-- bar的調(diào)用位置
}
function bar() {
// 當前調(diào)用棧是baz -> bar
// 因此,當前調(diào)用位置在baz中
console.log( "bar" );
foo(); // <-- foo的調(diào)用位置
}
function foo() {
// 當前調(diào)用棧是baz -> bar -> foo
// 因此,當前調(diào)用位置在bar中
console.log( "foo" );
}
baz(); // <-- baz的調(diào)用位置

多數(shù)現(xiàn)代桌面瀏覽器都內(nèi)置了開發(fā)者工具,其中包含JavaScript調(diào)試器。你可以在工具中給函數(shù)的第一行代碼設置一個斷點,或者直接在第一行代碼之前插入一條 debugger;語句。運行代碼時,調(diào)試器會在那個位置暫停,同時會展示當前位置的函數(shù)調(diào)用列表,這就是你的調(diào)用棧。因此,如果你想要分析this的綁定,使用開發(fā)者工具得到調(diào)用棧,然后找到棧中第二個元素,這就是真正的調(diào)用位置。

this 綁定規(guī)則

函數(shù)的調(diào)用位置決定了this的綁定對象,當我們找到調(diào)用位置后,然后判斷需要應用下面四條規(guī)則中的哪一條。

獨立函數(shù)調(diào)用

獨立函數(shù)調(diào)用,this 指向函數(shù)調(diào)用位置所在的包含環(huán)境對象。

function foo() {
console.log( this.a );
}
var a = 2;
foo(); // 2

作為對象的方法調(diào)用

當函數(shù)作為某個對象的方法被調(diào)用時,this 指向這個對象。

function foo() {
console.log( this.a );
}
var obj = {
a: 2,
foo: foo
};
obj.foo(); // 2

特別注意:雖然函數(shù)foo并不屬于obj對象,但調(diào)用位置使用obj的上下文來調(diào)用函數(shù)。我一直在強調(diào)調(diào)用位置的重要性,因為你可能一不留神就會忽略掉它,看下面的列子:

function foo() {
console.log( this.a );
}
var obj = {
a: 2,
foo: foo
};
var bar = obj.foo; // 函數(shù)別名! 步驟1
var a = "oops, global"; // a是全局對象的屬性
bar(); // "oops, global" 步驟2

在步驟1中,變量bar是obj.foo 的一個引用,它實際指向的是函數(shù)foo。所以使用bar()與直接使用foo()并沒有不同。

使用 .call/ .apply 綁定

每創(chuàng)建一個函數(shù),這個函數(shù)就有了兩個繼承而來的方法:call和apply。

它們的第一個參數(shù)是一個對象,它們會把這個對象綁定到this,接著在調(diào)用函數(shù)時指定這個 this 。因為你可以直接指定 this 的綁定對象,因此我們稱之為顯式綁定。

function foo() {
console.log( this.a );
}
var obj = {
a:2
};
foo.call( obj ); // 2

new綁定

使用 new 來調(diào)用函數(shù),或者說發(fā)生構造函數(shù)調(diào)用時,會自動執(zhí)行下面的操作。

  1. 創(chuàng)建(或者說構造)一個全新的對象。
  2. 這個新對象會被執(zhí)行[[原型]]連接,即指向構造函數(shù)的原型Foo.prototype。
  3. 這個新對象會綁定到函數(shù)調(diào)用的 this 。
  4. 如果函數(shù)沒有返回其他對象,那么 new 表達式中的函數(shù)調(diào)用會自動返回這個新對象。
function foo(a) {
this.a = a;
}
var bar = new foo(2);
console.log( bar.a ); // 2

使用 new 來調(diào)用 foo(..) 時,我們會構造一個新對象并把它綁定到 foo(..) 調(diào)用中的 this 上。

優(yōu)先級

如果要判斷一個運行中函數(shù)的this綁定,就需要找到這個函數(shù)的直接調(diào)用位置。找到之后就可以順序應用下面這四條規(guī)則來判斷 this 的綁定對象。

  1. 由 new 調(diào)用?綁定到新創(chuàng)建的對象。
  2. 由 call 或者 apply (或者 bind )調(diào)用?綁定到指定的對象。
  3. 由上下文對象調(diào)用?綁定到那個上下文對象。
  4. 默認:在嚴格模式下綁定到 undefined ,否則綁定到全局對象。

一定要注意,有些調(diào)用可能在無意中使用默認綁定規(guī)則。如果想“更安全”地忽略 this 綁定,你可以使用一個DMZ對象,比如 ø = Object.create(null) ,以保護全局對象。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向對象入門教程》、《JavaScript錯誤與調(diào)試技巧總結》、《JavaScript數(shù)據(jù)結構與算法技巧總結》及《JavaScript數(shù)學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

相關文章

  • javascript 循環(huán)調(diào)用示例介紹

    javascript 循環(huán)調(diào)用示例介紹

    循環(huán)調(diào)用,如果已經(jīng)獲取到了結果,則退出循環(huán),下面有個不錯的示例,感興趣的朋友可以嘗試操作下
    2013-11-11
  • 深入理解Javascript中this的作用域

    深入理解Javascript中this的作用域

    這篇文章主要介紹了深入理解Javascript中this的作用域,本文用大量例子來深入探討this的作用域,需要的朋友可以參考下
    2014-08-08
  • js調(diào)用瀏覽器打印模塊實現(xiàn)點擊按鈕觸發(fā)自定義函數(shù)

    js調(diào)用瀏覽器打印模塊實現(xiàn)點擊按鈕觸發(fā)自定義函數(shù)

    把瀏覽器打印的功能保留并賦予到自己添加的按鈕當中,可以在點擊按鈕的同時觸發(fā)自定義的函數(shù)
    2014-03-03
  • es6學習之解構時應該注意的點

    es6學習之解構時應該注意的點

    解構賦值允許你使用類似數(shù)組或對象字面量的語法將數(shù)組和對象的屬性賦給各種變量。這種賦值語法極度簡潔,同時還比傳統(tǒng)的屬性訪問方法更為清晰,下面這篇文章主要給大家介紹了關于在es6解構時應該注意的點,需要的朋友可以參考下。
    2017-08-08
  • 在JavaScript中使用嚴格模式(Strict Mode)

    在JavaScript中使用嚴格模式(Strict Mode)

    這篇文章主要介紹了在JavaScript中使用嚴格模式(Strict Mode),除了正常運行模式,ECMAscript 5添加了第二種運行模式:"嚴格模式"(strict mode)。顧名思義,這種模式使得Javascript在更嚴格的條件下運行。,需要的朋友可以參考下
    2019-06-06
  • js實現(xiàn)移動端編輯添加地址【模仿京東】

    js實現(xiàn)移動端編輯添加地址【模仿京東】

    本篇文章主要介紹了js實現(xiàn)移動端編輯添加地址[模仿京東]的實例。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • JavaScript避免嵌套代碼淺析

    JavaScript避免嵌套代碼淺析

    這篇文章主要介紹了JavaScript避免嵌套代碼,很多時候需要編寫的邏輯本身就很惡心, 乍看之下, 堆頁巖般的判定嵌套里似乎每一層都是必要的, 也只能說盡量讓它看起來不那么惡心
    2023-02-02
  • 微信小程序實現(xiàn)類似微信點擊語音播放效果

    微信小程序實現(xiàn)類似微信點擊語音播放效果

    這篇文章主要為大家詳細介紹了微信小程序實現(xiàn)類似微信點擊語音播放效果,不會互相干擾播放狀態(tài),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • js html實現(xiàn)計算器功能

    js html實現(xiàn)計算器功能

    這篇文章主要為大家詳細介紹了js html實現(xiàn)計算器功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • js實現(xiàn)旋轉木馬效果

    js實現(xiàn)旋轉木馬效果

    本文主要介紹了js實現(xiàn)旋轉木馬效果的實例。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03

最新評論