欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入理解JavaScript this綁定規(guī)則

 更新時(shí)間:2025年07月29日 09:26:02   作者:喜歡代碼的新之助  
在 JavaScript 中,this 是一個(gè)非常重要的關(guān)鍵字,this 的指向并不是固定的,而是根據(jù)函數(shù)的調(diào)用方式動(dòng)態(tài)決定的,本文就來(lái)介紹一下JavaScript this綁定規(guī)則,感興趣的可以了解一下

this綁定規(guī)則

this在全局作用域下指向

  • 全局作用域下的this指向window
  • 如果給元素的事件行為綁定函數(shù),那么函數(shù)中的this指向當(dāng)前被綁定的那個(gè)元素
  • 函數(shù)中的this,要看函數(shù)執(zhí)行前有沒有., 有.的話,點(diǎn)前面是誰(shuí),this就指向誰(shuí),如果沒有點(diǎn),指向window
  • 自執(zhí)行函數(shù)中的this永遠(yuǎn)指向window
  • 定時(shí)器中函數(shù)的this指向window
  • 構(gòu)造函數(shù)中的this指向當(dāng)前的實(shí)例
  • call、apply、bind可以改變函數(shù)的this指向
  • 箭頭函數(shù)中沒有this,如果輸出this,就會(huì)輸出箭頭函數(shù)定義時(shí)所在的作用域中的this

this的指向和函數(shù)所處的位置無(wú)關(guān),與函數(shù)被調(diào)用的方式有關(guān)

默認(rèn)綁定

當(dāng)函數(shù)是直接調(diào)用,而沒有被綁定到某個(gè)對(duì)象上進(jìn)行調(diào)用時(shí),this指向window

const obj = {
	name: '張三',
  foo: function () {
    console.log(this)
  }
}
const fn = obj.foo
fn() // window

隱式綁定

通過(guò)某個(gè)對(duì)象進(jìn)行調(diào)用

const obj1 = {
  name:'obj1',
  foo: function () {
    console.log(this)
  }
}

const obj2 = {
  name:'obj1',
  // 只是讓foo指向0bj1.foo,但是并沒有調(diào)用
  foo: obj1.foo
}

// foo函數(shù)是由obj2進(jìn)行調(diào)用的
obj2.foo() // {name: 'obj1', foo: ?}

顯式綁定

通過(guò)call()、apply()、bind()方法進(jìn)行調(diào)用,明確的改變函數(shù)的this指向

function sum (num1, num2, num3) {
  console.log(num1 + num2 + num3, this);
}
sum.call('call', 1, 2, 3); // 6 String {'call'}
sum.apply('apply', [1, 2, 3]); // String {'apply'}
const fn = sum.bind('bind', 1, 2, 3);
fn(); // 6 String {'bind'}

默認(rèn)綁定和顯示綁定沖突時(shí),顯示綁定的優(yōu)先級(jí)更高

new綁定

  1. JavaScript中的函數(shù)可以當(dāng)做一個(gè)類的構(gòu)造函數(shù)來(lái)使用,也就是使用new關(guān)鍵字

  2. 使用new關(guān)鍵字來(lái)調(diào)用函數(shù)是,會(huì)執(zhí)行如下的操作:

    1. 在內(nèi)存中創(chuàng)建一個(gè)新的空對(duì)象,如obj
    2. 對(duì)新創(chuàng)建的對(duì)象obj執(zhí)行prototype連接(obj.__proto__ = 函數(shù).prototype
    3. 讓this指向這個(gè)新的對(duì)象obj
    4. 執(zhí)行構(gòu)造函數(shù)里面的代碼,給這個(gè)對(duì)象添加屬性和方法
    5. 返回這個(gè)新對(duì)象obj(所以構(gòu)造函數(shù)里面不需要return)
    function Person (name) {
      this.name = name
    }
    
    const person1 = new Person('張三');
    person1.name // 張三
    const person2 = new Person('李四');
    person2.name // 李四
    

綁定優(yōu)先級(jí)

默認(rèn)規(guī)則this綁定的優(yōu)先級(jí)最低

顯示綁定優(yōu)先級(jí)高于隱式綁定

function foo () {
  console.log(this);
}
const obj = {
  name: '張三',
  fn: foo.bind('bind')
}
obj.fn() // String {'bind'}

new綁定優(yōu)先級(jí)高于隱式綁定

const obj = {
  name: '張三',
  foo: function () {
    console.log(this);
  }
}
var fn = new obj.foo(); // foo {}

new綁定優(yōu)先級(jí)高于顯示綁定(new綁定優(yōu)先級(jí)最高)

function Foo () {
  console.log(this) // Foo {}
}
var bar = Foo.bind('bind')
var foo = new Foo()
  • 注意new關(guān)鍵字無(wú)法和call()/apply()一起使用,因?yàn)?code>new、call()、apply()都是直接調(diào)用函數(shù)

特殊情況的this

  • 箭頭函數(shù):不遵循上述規(guī)則,this由外層作用域決定
  • DOM事件處理函數(shù):通常this指向觸發(fā)事件的元素
  • setTimeout/setInterval回調(diào):在非嚴(yán)格模式下默認(rèn)指向全局對(duì)象

到此這篇關(guān)于深入理解JavaScript this綁定規(guī)則的文章就介紹到這了,更多相關(guān)JavaScript this綁定規(guī)則內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • JavaScript閉包中難點(diǎn)深入分析

    JavaScript閉包中難點(diǎn)深入分析

    閉包是js的一個(gè)難點(diǎn)也是它的一個(gè)特色,是我們必須掌握的js高級(jí)特性,下面這篇文章主要給大家介紹了關(guān)于JavaScript閉包函數(shù)的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • PWA介紹及快速上手搭建一個(gè)PWA應(yīng)用的方法

    PWA介紹及快速上手搭建一個(gè)PWA應(yīng)用的方法

    這篇文章主要介紹了PWA介紹及快速上手搭建一個(gè)PWA應(yīng)用的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2019-01-01
  • 詳解JS轉(zhuǎn)換數(shù)值函數(shù)Number()、parseInt()、parseFloat()

    詳解JS轉(zhuǎn)換數(shù)值函數(shù)Number()、parseInt()、parseFloat()

    JS中有三種函數(shù)可以將非數(shù)值轉(zhuǎn)換成數(shù)值:Number()、parseInt()和parseFloat()。接下來(lái)通過(guò)本文詳細(xì)的給大家介紹JS轉(zhuǎn)換數(shù)值函數(shù)Number()、parseInt()、parseFloat()的實(shí)例代碼,感興趣的朋友一起看看吧
    2018-08-08
  • 原生JavaScript+LESS實(shí)現(xiàn)瀑布流

    原生JavaScript+LESS實(shí)現(xiàn)瀑布流

    這篇文章主要介紹了原生JavaScript+LESS實(shí)現(xiàn)瀑布流的方法,附上了具體實(shí)例,這里推薦給有需要的小伙伴。
    2014-12-12
  • iframe一次下載多個(gè)文件實(shí)例

    iframe一次下載多個(gè)文件實(shí)例

    這篇文章主要為大家介紹了iframe一次下載多個(gè)文件實(shí)現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-01-01
  • javascript中如何快速獲取數(shù)組最后一個(gè)值

    javascript中如何快速獲取數(shù)組最后一個(gè)值

    這篇文章主要介紹了javascript中如何快速獲取數(shù)組最后一個(gè)值問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • JavaScript遞歸函數(shù)定義與用法實(shí)例分析

    JavaScript遞歸函數(shù)定義與用法實(shí)例分析

    這篇文章主要介紹了JavaScript遞歸函數(shù)定義與用法,結(jié)合實(shí)例形式分析了javascript遞歸的原理、函數(shù)定義、使用方法及操作注意事項(xiàng),需要的朋友可以參考下
    2019-01-01
  • JavaScript數(shù)組類型Array相關(guān)的屬性與方法詳解

    JavaScript數(shù)組類型Array相關(guān)的屬性與方法詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)組類型Array相關(guān)的屬性與方法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-09-09
  • 實(shí)例代碼詳解javascript實(shí)現(xiàn)窗口抖動(dòng)及qq窗口抖動(dòng)

    實(shí)例代碼詳解javascript實(shí)現(xiàn)窗口抖動(dòng)及qq窗口抖動(dòng)

    這篇文章主要介紹了實(shí)例代碼詳解javascript實(shí)現(xiàn)窗口抖動(dòng)及qq窗口抖動(dòng)的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • video.js添加自定義組件的方法

    video.js添加自定義組件的方法

    這篇文章主要介紹了videojs添加自定義組件的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12

最新評(píng)論