精品秘无码一区二区三区老师-精品秘一区二三区免费雷安-精品蜜桃秘一区二区三区-精品蜜桃秘一区二区三区粉嫩-精品蜜桃一区二区三区-精品蜜臀国产aⅴ一区二区三区

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

JavaScript的this這個難點,難倒了多少小程序員!

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

?

this關鍵字是一個既強大又復雜的概念。它通常用于引用當前對象的上下文,但在不同的場景下,this的指向可能會發(fā)生變化。

一、this的基本含義

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

二、this在不同場景下的指向

  1. 全局上下文

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

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

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

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

    :當函數(shù)作為對象的一個方法被調(diào)用時,this指向該對象。

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

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

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

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

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); // 輸出被點擊的按鈕元素});

總結(jié)

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

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

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

主站蜘蛛池模板: 国产微拍精品一区二区 | 亚洲另类国产欧美一区二区一区二区日韩国产精品 | 亚洲av成人一区二区三区av | 精品四虎国产在免费观看 | 精品人体无码一区二区三区 | 国产麻豆精品免费密入口 | 91久久线看在观草草青青 | 国产伦精品一区二区三区精品 | 亚洲av日韩精品久久久久 | 日韩欧美不卡一区 | 色综合久久中文字幕无码 | 亚洲无码黄色免费网址 | 91麻豆精品国产专区在线观看 | 亚洲中日韩欧美高清在线 | 人妻系列无码专区免费视频 | 国产精品无码一区二区牛牛 | 国产成人无码精品久久二区三区 | 成人乱码一区二区三区av | 国产三级观看久久 | 精品国产麻豆免费人成网站 | 亚洲色图偷拍 | 国产乱人伦偷精品视频免下载 | 亚洲制服欧美自拍另类 | 色婷婷综合缴情综免费观看 | 国产精品日本无码久久一 | 成熟女人毛片WWW免费版在线 | 无码人妻视频一区二区 | 在线a人片免费观看国产 | 亚洲av成人精品日韩在线播放 | 欧美一区视频 | 国产免费成人在线视频 | 亚洲成av人片在线观看亚洲成a人片在线观看天堂无码 亚洲成av人片在线观看无线 | 国产美女视频国 | 亚洲中文字幕网资源站 | 无码人妻丰满熟妇奶水区码 | 亚洲AV无码一区二区三区性色学 | 精品久久久中文字幕人妻 | 亚洲国产日韩在线 | 国产乱人伦偷精品视频aaa | 三级大乳在线观看 | 一区二区三区乱码在线|欧洲 |