日韩欧美国产精品免费一二-日韩欧美国产精品亚洲二区-日韩欧美国产精品专区-日韩欧美国产另-日韩欧美国产免费看-日韩欧美国产免费看清风阁

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

JavaScript的this這個(gè)難點(diǎn),難倒了多少小程序員!

admin
2025年1月13日 18:58 本文熱度 744
JavaScript作為一門(mén)高級(jí)的、解釋型的編程語(yǔ)言,從誕生至今已有30年時(shí)間!應(yīng)用也越來(lái)越廣泛,從前端到后端  移動(dòng)端 PC端 可謂無(wú)處不在!那么今天要講的就是JavaScript最經(jīng)典的難點(diǎn) this指向問(wèn)題!

?

this關(guān)鍵字是一個(gè)既強(qiáng)大又復(fù)雜的概念。它通常用于引用當(dāng)前對(duì)象的上下文,但在不同的場(chǎng)景下,this的指向可能會(huì)發(fā)生變化。

一、this的基本含義

this在JavaScript中是一個(gè)特殊的關(guān)鍵字,它代表當(dāng)前執(zhí)行上下文中的一個(gè)對(duì)象。在大多數(shù)情況下,this指向調(diào)用它的對(duì)象。然而,在函數(shù)、箭頭函數(shù)、構(gòu)造函數(shù)、以及事件處理器等不同的上下文中,this的指向可能會(huì)有所不同。

二、this在不同場(chǎng)景下的指向

  1. 全局上下文

在全局執(zhí)行上下文中(即不在任何函數(shù)內(nèi)部),this指向全局對(duì)象。在瀏覽器環(huán)境中,全局對(duì)象是window;在Node.js環(huán)境中,全局對(duì)象是global

console.log(this === window); // 在瀏覽器中輸出 trueconsole.log(this === global); // 在Node.js中輸出 true
2.函數(shù)上下文

在普通函數(shù)中,this的指向取決于函數(shù)的調(diào)用方式。

  • 作為對(duì)象的方法調(diào)用

    :當(dāng)函數(shù)作為對(duì)象的一個(gè)方法被調(diào)用時(shí),this指向該對(duì)象。

const obj = {  name'Alice',  sayHellofunction() {    console.log(`Hello, my name is ${this.name}`);  }};obj.sayHello(); // 輸出 "Hello, my name is Alice"
3.作為普通函數(shù)調(diào)用
:當(dāng)函數(shù)不是作為對(duì)象的方法被調(diào)用時(shí)(即作為獨(dú)立函數(shù)),在非嚴(yán)格模式下,this指向全局對(duì)象;在嚴(yán)格模式下(使用'use strict'),thisundefined
function sayHello() {  console.log(this);}sayHello(); // 在非嚴(yán)格模式下輸出 window(或global),在嚴(yán)格模式下輸出 undefined
4.使用callapplybind方法
這些方法允許你顯式地設(shè)置this的指向。
const obj2 = { name'Bob' };sayHello.call(obj2); // 輸出 obj2 對(duì)象
5.箭頭函數(shù)

箭頭函數(shù)沒(méi)有自己的this綁定。它們會(huì)捕獲其所在上下文的this值作為自己的this值,這種行為稱(chēng)為“詞法作用域”或“靜態(tài)作用域”。

const obj3 = {  name'Charlie',  sayHello() => {    console.log(this.name); // 注意:這里的this不會(huì)指向obj3  }};obj3.sayHello(); // 輸出全局對(duì)象的name屬性(如果未定義則為undefined)
6.構(gòu)造函數(shù)

在構(gòu)造函數(shù)中,this指向新創(chuàng)建的對(duì)象實(shí)例。

function Person(name) {  this.name = name;}const person1 = new Person('David');console.log(person1.name); // 輸出 "David"

7.事件處理器

在事件處理器中,this通常指向觸發(fā)事件的元素。

document.getElementById('myButton').addEventListener('click'function() {  console.log(this); // 輸出被點(diǎn)擊的按鈕元素});

總結(jié)

  • 1.this的指向取決于函數(shù)的調(diào)用方式,而不是函數(shù)被定義的位置。

  • 2.箭頭函數(shù)沒(méi)有自己的this綁定,它們會(huì)捕獲其所在上下文的this值。
  • 3.在使用this時(shí),要特別注意函數(shù)的調(diào)用方式以及是否處于嚴(yán)格模式。
  • 4.理解this的指向是掌握J(rèn)avaScript面向?qū)ο缶幊痰年P(guān)鍵。

該文章在 2025/1/13 18:58:13 編輯過(guò)
關(guān)鍵字查詢(xún)
相關(guān)文章
正在查詢(xún)...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專(zhuān)業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車(chē)隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類(lèi)企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷(xiāo)售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶(hù)的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 午夜福利 | 国产农村乱子伦精品视频 | 91三级在线日韩精品片 | 国产女女互摸互慰在线观 | 一区二区三区视频在线播放 | 亚洲国产精品视频免费观看 | 在线观看午夜福利片日本 | 2025年亚洲欧美在线v | 中文字幕国产专区99 | 国产在线观看一区二区三区 | 日韩在线成年视频人网站观看 | 99精品全国免费观看视频 | 蝌蚪一个释放的网站 | 99久热只有精品视频免费看 | 国产亚洲玖玖玖在线观看 | 美女免费精品 | 国产一级大片在线观看 | 国产乱理伦片在线观看网站 | 亚洲欧美日韩综合一区 | 日本黄页网址在线 | 精品欧美视频第二页在线观看 | 欧美韩日二三在 | 男女直接做无 | 国产一区二区四五区在线视频 | 国产男生夜间福利免费网站 | 国产一区二区三区在线啊 | 国产又黄又爽视频免费观 | 91精品视频在线 | 日本一本在 | 91精品一区二区三区蜜桃 | 好看的手机电影 | 日韩精品一区二区免费在线观看 | 国产农村乱子伦精品视频 | 亚洲国产美国国产综合一区 | 亚洲男人片片在线观看 | 精品在线观看亚洲中文 | 国产亚洲欧洲精品一区二区三区 | 精品午夜一区 | 国产精品色三级在线观看 | 手机看片福利一区二区三区 | aⅴ国产在线观看 |