1. 程式人生 > 其它 >JavaScript this 關鍵字

JavaScript this 關鍵字

面嚮物件語言中 this 表示當前物件的一個引用。

但在 JavaScript 中 this 不是固定不變的,它會隨著執行環境的改變而改變。

  • 在方法中,this 表示該方法所屬的物件。
  • 如果單獨使用,this 表示全域性物件。
  • 在函式中,this 表示全域性物件。
  • 在函式中,在嚴格模式下,this 是未定義的(undefined)。
  • 在事件中,this 表示接收事件的元素。
  • 類似 call() 和 apply() 方法可以將 this 引用到任何物件。

顯式函式繫結

在 JavaScript 中函式也是物件,物件則有方法,apply 和 call 就是函式物件的方法。這兩個方法異常強大,他們允許切換函式執行的上下文環境(context),即 this 繫結的物件。

在下面例項中,當我們使用 person2 作為引數來呼叫 person1.fullName 方法時,this將指向 person2, 即便它是 person1 的方法:

例項

var person1 = { fullName: function() { return this.firstName + " " + this.lastName; } } var person2 = { firstName:"John", lastName: "Doe", } person1.fullName.call(person2); // 返回 "John Doe"