中文字幕一区二区人妻电影,亚洲av无码一区二区乱子伦as ,亚洲精品无码永久在线观看,亚洲成aⅴ人片久青草影院按摩,亚洲黑人巨大videos

JavaScript this

面向?qū)ο笳Z(yǔ)言中 this 表示當(dāng)前對(duì)象的一個(gè)引用。

但在 JavaScript 中 this 不是固定不變的,它會(huì)隨著執(zhí)行環(huán)境的改變而改變。

  • 在方法中,this 表示該方法所屬的對(duì)象。
  • 如果單獨(dú)使用,this 表示全局對(duì)象。
  • 在函數(shù)中,this 表示全局對(duì)象。
  • 在函數(shù)中,在嚴(yán)格模式下,this 是未定義的(undefined)。
  • 在事件中,this 表示接收事件的元素。
  • 類似 call() 和 apply() 方法可以將 this 引用到任何對(duì)象。

實(shí)例

var person = { firstName: "John", lastName : "Doe", id : 5566, fullName : function() { return this.firstName + " " + this.lastName; } };

運(yùn)行代碼 ?

方法中的 this

在對(duì)象方法中, this 指向調(diào)用它所在方法的對(duì)象。

在上面一個(gè)實(shí)例中,this 表示 person 對(duì)象。

fullName 方法所屬的對(duì)象就是 person。

實(shí)例

fullName : function() { return this.firstName + " " + this.lastName; }

運(yùn)行代碼 ?

單獨(dú)使用 this

單獨(dú)使用 this,則它指向全局(Global)對(duì)象。

在瀏覽器中,window 就是該全局對(duì)象為 [object Window]:

實(shí)例

var x = this;

運(yùn)行代碼 ?

嚴(yán)格模式下,如果單獨(dú)使用,this 也是指向全局(Global)對(duì)象。

實(shí)例

"use strict"; var x = this;

運(yùn)行代碼 ?

函數(shù)中使用 this(默認(rèn))

在函數(shù)中,函數(shù)的所屬者默認(rèn)綁定到 this 上。

在瀏覽器中,window 就是該全局對(duì)象為 [object Window]:

實(shí)例

function myFunction() { return this; }

運(yùn)行代碼 ?

函數(shù)中使用 this(嚴(yán)格模式)

嚴(yán)格模式下函數(shù)是沒有綁定到 this 上,這時(shí)候 this 是 undefined。

實(shí)例

"use strict"; function myFunction() { return this; }

運(yùn)行代碼 ?

事件中的 this

在 HTML 事件句柄中,this 指向了接收事件的 HTML 元素:

實(shí)例

<button onclick="this.style.display='none'"> 點(diǎn)我后我就消失了 </button>

運(yùn)行代碼 ?

對(duì)象方法中綁定

下面實(shí)例中,this 是 person 對(duì)象,person 對(duì)象是函數(shù)的所有者:

實(shí)例

var person = { firstName : "John", lastName : "Doe", id : 5566, myFunction : function() { return this; } };

運(yùn)行代碼 ?

實(shí)例

var person = { firstName: "John", lastName : "Doe", id : 5566, fullName : function() { return this.firstName + " " + this.lastName; } };

運(yùn)行代碼 ?

說明: this.firstName 表示 this (person) 對(duì)象的 firstName 屬性。


顯式函數(shù)綁定

在 JavaScript 中函數(shù)也是對(duì)象,對(duì)象則有方法,apply 和 call 就是函數(shù)對(duì)象的方法。這兩個(gè)方法異常強(qiáng)大,他們?cè)试S切換函數(shù)執(zhí)行的上下文環(huán)境(context),即 this 綁定的對(duì)象。

在下面實(shí)例中,當(dāng)我們使用 person2 作為參數(shù)來(lái)調(diào)用 person1.fullName 方法時(shí), this 將指向 person2, 即便它是 person1 的方法:

實(shí)例

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

運(yùn)行代碼 ?