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

JavaScript?中?this?關(guān)鍵字的作用及改變其上下文的方法

 更新時間:2023年01月23日 09:17:19   作者:yuzhihui  
這篇文章主要介紹了JavaScript?中?this?關(guān)鍵字的作用和如何改變其上下文,通過使用?call,?apply,?bind?方法,可以改變函數(shù)中的?this?指向,從而在不同的上下文中使用同一個函數(shù),需要的朋友可以參考下

JavaScript 中的 this 關(guān)鍵字引用了所在函數(shù)正在被調(diào)用時的對象。在不同的上下文中,this 的指向會發(fā)生變化??梢酝ㄟ^ call, apply, bind 方法來改變 this 的上下文。

一、this 關(guān)鍵字的作用

JavaScript 中的 this 關(guān)鍵字引用了所在函數(shù)正在被調(diào)用時的對象。在不同的上下文中,this 的指向會發(fā)生變化。

在全局上下文中,this 指向全局對象(在瀏覽器中是 window 對象,在 Node.js 中是 global 對象)。

在函數(shù)中,this 指向調(diào)用該函數(shù)的對象。如果該函數(shù)是通過對象的方法調(diào)用的,那么 this 指向該對象;如果是通過函數(shù)調(diào)用的,那么 this 指向全局對象。

在箭頭函數(shù)中,this 繼承自父級作用域中的 this。

在類的構(gòu)造函數(shù)中,使用 new 關(guān)鍵字調(diào)用類時,this 指向新創(chuàng)建的對象。

例如:

class MyClass {
  constructor() {
    this.value = 42;
  }
}

let obj = new MyClass();
console.log(obj.value); // 42

類的實例方法中的 this 默認(rèn)指向?qū)嵗旧?,類方法中?this 默認(rèn)指向類本身。

例如:

class MyClass {
  value = 42;
  printValue() {
    console.log(this.value);
  }
  static printValue() {
    console.log(this.value);
  }
}

let obj = new MyClass();
obj.printValue(); // 42
MyClass.printValue(); // undefined

使用 Object.create 方法創(chuàng)建對象

使用 Object.create 方法創(chuàng)建是一種特殊的調(diào)用方式。在這種情況下,如果在對象的原型鏈上調(diào)用函數(shù),則 this 指向該對象。

例如:

let baseObject = { value: 42 };
let obj = Object.create(baseObject);

function printValue() {
  console.log(this.value);
}

printValue.call(obj); // 42

這種情況下, obj 的原型鏈上有 value 屬性,所以調(diào)用 printValue() 方法時, this 指向 obj 對象。

在類中使用箭頭函數(shù)

類中使用箭頭函數(shù)定義的方法中的 this 指向是綁定的,它指向的是類的實例,而不是類本身。

例如:

class MyClass {
  value = 42;
  printValue = () => {
    console.log(this.value);
  }
}
let obj = new MyClass();
obj.printValue(); // 42

箭頭函數(shù)的 this 是定義時的 this,而不是調(diào)用時的 this。因此,在類中使用箭頭函數(shù)可以避免在方法中使用 bind 來綁定 this。

在調(diào)用構(gòu)造函數(shù)時,未使用 new 關(guān)鍵字

在這種情況下,this 指向全局對象。這種情況下不會創(chuàng)建新的對象,而是改變了全局對象的狀態(tài)。

例如:

class MyClass {
  constructor() {
    this.value = 42;
  }
}

let obj = MyClass(); // without new keyword
console.log(obj); // undefined
console.log(value); // 42

因此,在使用構(gòu)造函數(shù)創(chuàng)建對象時,需要確保使用 new 關(guān)鍵字來調(diào)用構(gòu)造函數(shù),否則可能會導(dǎo)致意外的結(jié)果。

在使用構(gòu)造函數(shù)時特別需要注意使用 new 關(guān)鍵字來調(diào)用。

在對象的方法中使用箭頭函數(shù)會導(dǎo)致 this 指向問題

例如:

let obj = {
  value: 42,
  printValue: () => {
    console.log(this.value);
  }
};
obj.printValue(); // undefined

這種情況下,在 obj 對象的 printValue 方法中使用了箭頭函數(shù),而箭頭函數(shù)的 this 指向是定義時的 this,而不是調(diào)用時的 this。在這種情況下,因為箭頭函數(shù)的 this 指向是定義時的 this,所以 this.value 指向的是 undefined,而不是 obj 對象中的 value。

解決這種問題可以使用箭頭函數(shù)的父級作用域中的 this,或者使用普通函數(shù)來解決。

例如:

let obj = {
  value: 42,
  printValue: function(){
    console.log(this.value);
  }
};
obj.printValue(); // 42

或者

let obj = {
  value: 42,
  printValue: () => {
    console.log(obj.value);
  }
};
obj.printValue(); // 42

在對象的方法中使用箭頭函數(shù)會導(dǎo)致 this 指向問題,需要特別注意??梢允褂眉^函數(shù)的父級作用域中的 this 或者普通函數(shù)來解決。

總之,JavaScript 中的 this 關(guān)鍵字指向的上下文取決于函數(shù)的調(diào)用方式,需要根據(jù)不同的場景來選擇合適的方式來改變 this 的指向。

二、如何改變 this 上下文

可以通過 call, apply, bind 方法來改變 this 的上下文。

callapply 方法允許您將函數(shù)的 this 指向指定的對象,并立即執(zhí)行該函數(shù)。

call 方法的語法格式如下:

functionName.call(thisArg, arg1, arg2, ...);

apply 方法的語法格式如下:

functionName.apply(thisArg, [arg1, arg2, ...]);

bind 方法允許您將函數(shù)的 this 指向指定的對象,但不立即執(zhí)行函數(shù),而是返回一個新函數(shù),可以在將來執(zhí)行。

let newFunc = functionName.bind(thisArg, arg1, arg2, ...);

例如:

let obj = {value: 42};

function printValue() {
  console.log(this.value);
}

printValue.call(obj); // 42
printValue.apply(obj); // 42
let boundFunc = printValue.bind(obj);
boundFunc(); // 42

總之,通過使用 call, apply, bind 方法,可以改變函數(shù)中的 this 指向,從而在不同的上下文中使用同一個函數(shù)。

到此這篇關(guān)于JavaScript 中 this 關(guān)鍵字的作用和如何改變其上下文的文章就介紹到這了,更多相關(guān)js this關(guān)鍵字作用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • bootstrap laydate日期組件使用詳解

    bootstrap laydate日期組件使用詳解

    這篇文章主要為大家詳細(xì)介紹了bootstrap laydate日期組件使用,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • bootstrap模態(tài)框跳轉(zhuǎn)到當(dāng)前模板頁面 框消失了而背景存在問題的解決方法

    bootstrap模態(tài)框跳轉(zhuǎn)到當(dāng)前模板頁面 框消失了而背景存在問題的解決方法

    這篇文章主要介紹了bootstrap模態(tài)框跳轉(zhuǎn)到當(dāng)前模板頁面,框消失了,而背景依然存在問題的解決方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • javascript parseInt 大改造

    javascript parseInt 大改造

    還隱約記得第一次遇到 parseInt這個詭異問題的時候,以為發(fā)現(xiàn)了IE的BUG,興奮不已。
    2009-09-09
  • JavaScript 計算圖片加載數(shù)量的代碼

    JavaScript 計算圖片加載數(shù)量的代碼

    先定義一個圖片的數(shù)組,然后通過image的onload事件來計算,注意,onload在ie和火狐有所不同。
    2011-01-01
  • js逆向解密之網(wǎng)絡(luò)爬蟲

    js逆向解密之網(wǎng)絡(luò)爬蟲

    在本篇內(nèi)容里小編給大家整理的是關(guān)于js逆向解密之網(wǎng)絡(luò)爬蟲的相關(guān)知識點內(nèi)容,需要的朋友們參考下。
    2019-05-05
  • 前端實現(xiàn)打印功能的兩種方法詳解

    前端實現(xiàn)打印功能的兩種方法詳解

    當(dāng)頁面設(shè)計好后需要打印出來,如網(wǎng)頁的的打印瀏覽和打印功能,有些公司需要讓前端開發(fā)好頁面打印出來或者轉(zhuǎn)為pdf格式的文檔,下面這篇文章主要給大家介紹了關(guān)于前端實現(xiàn)打印功能的兩種方法,需要的朋友可以參考下
    2023-01-01
  • JS簡單實現(xiàn)仿百度控制臺輸出信息效果

    JS簡單實現(xiàn)仿百度控制臺輸出信息效果

    這篇文章主要介紹了JS簡單實現(xiàn)仿百度控制臺輸出信息效果,涉及javascript中console.log函數(shù)的簡單使用技巧,需要的朋友可以參考下
    2016-09-09
  • 網(wǎng)頁禁止鼠標(biāo)左右鍵功能的簡單代碼

    網(wǎng)頁禁止鼠標(biāo)左右鍵功能的簡單代碼

    本篇文章介紹與演示網(wǎng)頁禁止鼠標(biāo)左右鍵的實例代碼,需要的朋友可以參考一下
    2013-06-06
  • ES6之Proxy的get方法詳解

    ES6之Proxy的get方法詳解

    這篇文章主要介紹了ES6之Proxy的get方法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • 超全面的JavaScript開發(fā)規(guī)范(推薦)

    超全面的JavaScript開發(fā)規(guī)范(推薦)

    作為一名開發(fā)人員(WEB前端JavaScript開發(fā)),不規(guī)范的開發(fā)不僅使日后代碼維護(hù)變的困難,同時也不利于團(tuán)隊的合作,通常還會帶來代碼安全以及執(zhí)行效率上的問題。本文就主要介紹了關(guān)于Javascript的命名規(guī)范、注釋規(guī)范以及框架開發(fā)的一些問題,需要的朋友可以參考學(xué)習(xí)。
    2017-01-01

最新評論