javascript
java script this_JavaScript this 关键字
JavaScript this 關(guān)鍵字
面向?qū)ο笳Z言中 this 表示當(dāng)前對象的一個引用。
但在 JavaScript 中 this 不是固定不變的,它會隨著執(zhí)行環(huán)境的改變而改變。
在方法中,this 表示該方法所屬的對象。
如果單獨(dú)使用,this 表示全局對象。
在函數(shù)中,this 表示全局對象。
在函數(shù)中,在嚴(yán)格模式下,this 是未定義的(undefined)。
在事件中,this 表示接收事件的元素。
類似 call() 和 apply() 方法可以將 this 引用到任何對象。
實(shí)例
varperson={firstName:"John",lastName:"Doe",id:5566,fullName:function(){returnthis.firstName+""+this.lastName;}};
嘗試一下 ?
方法中的 this
在對象方法中, this 指向調(diào)用它所在方法的對象。
在上面一個實(shí)例中,this 表示 person 對象。
fullName 方法所屬的對象就是 person。
實(shí)例
fullName:function(){returnthis.firstName+""+this.lastName;}
嘗試一下 ?
單獨(dú)使用 this
單獨(dú)使用 this,則它指向全局(Global)對象。
在瀏覽器中,window 就是該全局對象為 [object Window]:
實(shí)例
varx=this;
嘗試一下 ?
嚴(yán)格模式下,如果單獨(dú)使用,this 也是指向全局(Global)對象。
實(shí)例
"use strict";varx=this;
嘗試一下 ?
函數(shù)中使用 this(默認(rèn))
在函數(shù)中,函數(shù)的所屬者默認(rèn)綁定到 this 上。
在瀏覽器中,window 就是該全局對象為 [object Window]:
實(shí)例
functionmyFunction(){returnthis;}
嘗試一下 ?
函數(shù)中使用 this(嚴(yán)格模式)
嚴(yán)格模式下函數(shù)是沒有綁定到 this 上,這時候 this 是 undefined。
實(shí)例
"use strict";functionmyFunction(){returnthis;}
嘗試一下 ?
事件中的 this
在 HTML 事件句柄中,this 指向了接收事件的 HTML 元素:
實(shí)例
點(diǎn)我后我就消失了
嘗試一下 ?
對象方法中綁定
下面實(shí)例中,this 是 person 對象,person 對象是函數(shù)的所有者:
實(shí)例
varperson={firstName:"John",lastName:"Doe",id:5566,myFunction:function(){returnthis;}};
嘗試一下 ?
實(shí)例
varperson={firstName:"John",lastName:"Doe",id:5566,fullName:function(){returnthis.firstName+""+this.lastName;}};
嘗試一下 ?
說明: this.firstName 表示
this (person) 對象的 firstName 屬性。
顯式函數(shù)綁定
在 JavaScript 中函數(shù)也是對象,對象則有方法,apply 和 call 就是函數(shù)對象的方法。這兩個方法異常強(qiáng)大,他們允許切換函數(shù)執(zhí)行的上下文環(huán)境(context),即 this 綁定的對象。
在下面實(shí)例中,當(dāng)我們使用 person2 作為參數(shù)來調(diào)用 person1.fullName 方法時, this 將指向 person2, 即便它是 person1 的方法:
實(shí)例
varperson1={fullName:function(){returnthis.firstName+""+this.lastName;}}varperson2={firstName:"John",lastName:"Doe",}person1.fullName.call(person2);//返回 "John Doe"
嘗試一下 ?
總結(jié)
以上是生活随笔為你收集整理的java script this_JavaScript this 关键字的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 鱼籽多少钱啊?
- 下一篇: java url帮助类_Spring居然