首頁 > web前端 > js教程 > JavaScript 物件文字中的「this」關鍵字如何表現?

JavaScript 物件文字中的「this」關鍵字如何表現?

Patricia Arquette
發布: 2024-12-13 21:48:21
原創
687 人瀏覽過

How Does the `this` Keyword Behave in JavaScript Object Literals?

Javascript 物件文字中的「this」關鍵字行為

在物件文字中,「this」關鍵字用作物件的佔位符本身。但是,它的行為可能會根據呼叫它的條件而有所不同。

在您的程式碼中:

var MyDate = function(date) {
    this.date = date;
};

var obj1 = {
    foo: new Date(),
    bar: new MyDate(this.foo)  //  this.foo is undefined
};

var obj2 = {};
obj2.foo = new Date();
obj2.bar = new MyDate(this.foo);  //  this.foo is undefined

var obj3 = {
    foo: new Date(),
    bar: new MyDate(obj3.foo)
};

var obj4 = {};
obj4.foo = new Date();
obj4.bar = new MyDate(obj4.foo);
登入後複製

理解「this」綁定

Javascript 的「this」關鍵字表現出後期綁定定,這意味著它的值在呼叫函數之前才確定。在您的情況下:

場景1 和2:

  • 在「obj1」和「obj2」中,「new MyDate」中的「this ”關鍵字函數引用全域物件(即“視窗”),因為它們不作為特定物件的方法呼叫。由於全域物件上沒有名為“foo”的屬性,因此會導致未定義的錯誤。

場景3 和4:

  • 中「obj3」和「obj4」中,「this」關鍵字成功引用了各自的物件,因為“new MyDate”函數被當作這些物體。因此,「this.foo」正確地存取了每個物件中的「foo」屬性。

結論

物件中「this」關鍵字的行為文字取決於呼叫函數的上下文。如果沒有明確綁定到對象,則預設為全域對象。但是,當作為對象的方法呼叫時,它會引用該特定對象,確保正確存取該對象的屬性和方法。

以上是JavaScript 物件文字中的「this」關鍵字如何表現?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板