亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

用最簡(jiǎn)單的方法判斷JavaScript中this的指向(推薦)

 更新時(shí)間:2017年09月04日 08:38:33   作者:bergwhite  
都說(shuō) JavaScript 是一種很靈活的語(yǔ)言,這其實(shí)也可以說(shuō)它是一個(gè)混亂的語(yǔ)言,下面通過(guò)本文給大家分享JavaScript中this的指向知識(shí),感興趣的朋友一起看看吧

都說(shuō) JavaScript 是一種很靈活的語(yǔ)言,這其實(shí)也可以說(shuō)它是一個(gè)混亂的語(yǔ)言。它把 函數(shù)式編程 和 面向?qū)ο缶幊?糅合一起,再加上 動(dòng)態(tài)語(yǔ)言 特性,簡(jiǎn)直強(qiáng)大無(wú)比(其實(shí)是不能和C++比的,^_^ )。

JS 里的 this

  • 在 function 內(nèi)部被創(chuàng)建
  • 指向調(diào)用時(shí)所在函數(shù)所綁定的對(duì)象(拗口)
  • this 不能被賦值,但可以被 call/apply  改變

目錄

* 一個(gè)特例
* 開始判斷
    * 法則一:對(duì)象方法中的this指向?qū)ο蟊旧恚^函數(shù)形式的除外)
    * 法則二:多層嵌套函數(shù)中的this指向等同于包含該this的最近一個(gè)function的this
    * 法則三:箭頭函數(shù)以及非指向?qū)ο蠓椒ㄖ械膄unction的情況下this指向window
* 習(xí)題集
    * 普通函數(shù)中的this
    * 函數(shù)執(zhí)行后返回另外一個(gè)函數(shù)中的this(普通函數(shù)中)
    * 多層嵌套函數(shù)中的this(定時(shí)器&箭頭函數(shù))1
    * 多層嵌套函數(shù)中的this(定時(shí)器&箭頭函數(shù))2

一個(gè)特例

在正式開始之前,我們先來(lái)說(shuō)一個(gè)特例。

// 構(gòu)造函數(shù)
function Student(name) {
 this.name = name
}
// 創(chuàng)建小明和小紅兩個(gè)實(shí)例
var XM = new Student('xiaoming')
var XH = new Student('xiaohong')
// 輸出信息
console.log(XM) // Student {name: "xiaoming"}
console.log(XH) // Student {name: "xiaohong"}

在構(gòu)造函數(shù)中,this上的值會(huì)在創(chuàng)建實(shí)例的時(shí)候被綁定到新創(chuàng)建的實(shí)例上。不適用于下面的判斷方法,所以特此說(shuō)明。

開始判斷

下面是一個(gè)典型例子,我們的分析從這里開始。

var x = {
 name: 'bw2',
 getName1: function() {
 console.log(this)
 },
 getName2: function() {
 setTimeout(() => {
  console.log(this)
 },0)
 },
 getName31: () => {
 console.log(this)
 },
 getName32: function() {
 return function() {
  console.log(this)
 }
 }
}
x.getName1() // {name: "bw2", getName1: ƒ}
x.getName2() // {name: "bw2", getName1: ƒ}
x.getName31() // Window {stop: ƒ, open: ƒ, alert: ƒ, confirm: ƒ, prompt: ƒ, …}
x.getName32()() // Window {stop: ƒ, open: ƒ, alert: ƒ, confirm: ƒ, prompt: ƒ, …}

法則一:對(duì)象方法中的this指向?qū)ο蟊旧恚^函數(shù)形式的除外)

var x = {
 name: 'bw2',
 getName1: function() {
 console.log(this)
 }
}
x.getName1() // {name: "bw2", getName1: ƒ}

法則二:多層嵌套函數(shù)中的this指向等同于包含該this的最近一個(gè)function的this

箭頭函數(shù)沒有獨(dú)立的this作用域,所以繼續(xù)往外層走,走到了getName: function(){}。那么就是他了,this指向等同于這個(gè)function內(nèi)部的this指向。根據(jù)法則一,this指向?qū)ο蟊旧怼?/p>

var x = {
 name: 'bw2',
 getName2: function() {
 console.log(this) // 等同于此處的this
 setTimeout(() => {
  console.log(this) // 原始的this位置
 },0)
 }
}
x.getName2() // {name: 'bw2', getName1: ƒ}

我們可以試著在瀏覽器中運(yùn)行,看看結(jié)果。

法則三:箭頭函數(shù)以及非指向?qū)ο蠓椒ㄖ械膄unction的情況下this指向window

根據(jù)法則二,this是指向最近的function,因此,這里的this等同于返回的函數(shù)中的this,不是對(duì)象方法中的this,所以,指向全局。

是不是感覺有點(diǎn)奇怪?不過(guò)實(shí)踐證明確實(shí)如此。

var x = {
 name: 'bw2',
 getName31: () => {
 console.log(this)
 },
 getName32: function() {
 return function() {
  console.log(this)
 }
 }
}
x.getName31() // Window {stop: ƒ, open: ƒ, alert: ƒ, confirm: ƒ, prompt: ƒ, …}
x.getName32()() // Window {stop: ƒ, open: ƒ, alert: ƒ, confirm: ƒ, prompt: ƒ, …}

習(xí)題集

歡迎大家按照法則一到三依次判斷,猜測(cè)結(jié)果,并在瀏覽器下測(cè)試。測(cè)試結(jié)果也可以回復(fù),大家一起討論。

因本人能力有限,該系列法則可能在部分情況下失效。歡迎大家一起討論。

下面是做題時(shí)間。

普通函數(shù)中的this

function x() {
 console.log(this)
}
x()

函數(shù)執(zhí)行后返回另外一個(gè)函數(shù)中的this(普通函數(shù)中)

function xx(){
 return function() {
 console.log(this)
 }
}
xx()()

多層嵌套函數(shù)中的this(定時(shí)器&箭頭函數(shù))1

var x = {
 name: 'bw2',
 getName: () => {
 setTimeout(() => {
  console.log(this)
 },0)
 }
}
x.getName()

多層嵌套函數(shù)中的this(定時(shí)器&箭頭函數(shù))2

var x = {
 name: 'bw2',
 getName: () => {
 setTimeout(function() {
  console.log(this)
 },0)
 }
}
x.getName()

再次說(shuō)明,該法則為實(shí)驗(yàn)性法則,未進(jìn)行大范圍的測(cè)試,不保證在所有情況下都有一致的結(jié)果。如果你發(fā)現(xiàn)了法則判斷失敗的情況,歡迎留言,一起探討。

總結(jié)

以上所述是小編給大家介紹的Mysql 5.7.19 winx64 ZIP Archive 安裝及使用教程,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • JS三級(jí)可折疊菜單實(shí)現(xiàn)方法

    JS三級(jí)可折疊菜單實(shí)現(xiàn)方法

    這篇文章主要介紹了JS三級(jí)可折疊菜單實(shí)現(xiàn)方法,以實(shí)例形式分析了asp.net結(jié)合JavaScript實(shí)現(xiàn)三級(jí)折疊菜單的相關(guān)技巧,涉及JavaScript節(jié)點(diǎn)操作實(shí)現(xiàn)方法,需要的朋友可以參考下
    2016-02-02
  • 淺談鴻蒙 JavaScript GUI 技術(shù)棧

    淺談鴻蒙 JavaScript GUI 技術(shù)棧

    眾所周知,剛剛開源的「鴻蒙 2.0」以 JavaScript 作為 IoT 應(yīng)用開發(fā)的框架語(yǔ)言。作為科普,這篇文章不會(huì)拿著放大鏡找出代碼中的槽點(diǎn)來(lái)吹毛求疵,而是希望通俗地講清楚它所支持的 GUI 到底是怎么一回事。
    2020-09-09
  • 原生JS獲取URL鏈接參數(shù)的幾種常見方法

    原生JS獲取URL鏈接參數(shù)的幾種常見方法

    這篇文章主要給大家介紹了關(guān)于利用原生JS獲取URL鏈接參數(shù)的幾種常見方法,文中通過(guò)實(shí)例代碼以及圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-03-03
  • JavaScript實(shí)現(xiàn)矩形塊大小任意縮放

    JavaScript實(shí)現(xiàn)矩形塊大小任意縮放

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)矩形塊大小任意縮放,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-08-08
  • JS實(shí)現(xiàn)為動(dòng)態(tài)創(chuàng)建的元素添加事件操作示例

    JS實(shí)現(xiàn)為動(dòng)態(tài)創(chuàng)建的元素添加事件操作示例

    這篇文章主要介紹了JS實(shí)現(xiàn)為動(dòng)態(tài)創(chuàng)建的元素添加事件操作,涉及javascript頁(yè)面元素動(dòng)態(tài)添加及事件響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下
    2018-03-03
  • js實(shí)現(xiàn)可以點(diǎn)擊收縮或張開的懸浮窗

    js實(shí)現(xiàn)可以點(diǎn)擊收縮或張開的懸浮窗

    這篇文章主要介紹了js實(shí)現(xiàn)可以點(diǎn)擊收縮或張開的懸浮窗效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • 原生js實(shí)現(xiàn)焦點(diǎn)輪播圖效果

    原生js實(shí)現(xiàn)焦點(diǎn)輪播圖效果

    本文主要分享了原生js實(shí)現(xiàn)焦點(diǎn)輪播圖效果的示例代碼,并解析了實(shí)例中的注意點(diǎn)。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧
    2017-01-01
  • Bootstrap 粘頁(yè)腳效果

    Bootstrap 粘頁(yè)腳效果

    Bootstrap 粘頁(yè)腳,說(shuō)得具體一點(diǎn)就是“將固定高度的頁(yè)腳緊貼頁(yè)面底部”,本文給大家分享具有實(shí)現(xiàn)代碼,感興趣的朋友參考下吧
    2016-03-03
  • layui結(jié)合form,table的全選、反選v1.0示例講解

    layui結(jié)合form,table的全選、反選v1.0示例講解

    今天小編就為大家分享一篇layui結(jié)合form,table的全選、反選v1.0示例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 前端必會(huì)的圖片懶加載(三種方式)

    前端必會(huì)的圖片懶加載(三種方式)

    在我們?cè)L問(wèn)一個(gè)圖片展示比較多的網(wǎng)頁(yè)時(shí),加載速度慢很多時(shí)候正是因?yàn)閳D片多導(dǎo)致,本文主要介紹了前端必會(huì)的圖片懶加載(三種方式),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評(píng)論