999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

JavaScript語言中this指向研究

2021-10-18 00:49:24周虎
電腦知識與技術(shù) 2021年26期

周虎

摘要:JavaScript逐漸從一門簡單的腳本語言進化成為一門強大的面向?qū)ο缶幊陶Z言,尤其在對象的this指向上,不僅借鑒了其他高級語言的優(yōu)點,并結(jié)合自身靈活的編程能力,在程序運行中可以動態(tài)改變this指向。該文針對this在全局變量、函數(shù)、對象中的指向,以及通過apply、call和bind改變綁定對象后this的指向進行了深入的探討并進行了總結(jié)歸納,便于讀者更深層次的理解JavaScript中的this指向問題。

關(guān)鍵詞:JavaScript;this;bind;apply;call

中圖分類號:TP312? ? ? 文獻標(biāo)識碼:A

文章編號:1009-3044(2021)26-0162-02

開放科學(xué)(資源服務(wù))標(biāo)識碼(OSID):

1 背景

JavaScript是面向Web的編程語言,其動態(tài)以及面向?qū)ο蟮木幊田L(fēng)格使得它已經(jīng)從一門簡單的腳本語言進化成為一門強大的編程語言[1]。在高級語言面向?qū)ο缶幊踢^程中,都會用到this關(guān)鍵字,一般用來指向構(gòu)建的對象,同樣在JavaScript編程語言中,在很多情況下也會用到this關(guān)鍵字,this在其不同的上下文環(huán)境中,this的指向會各不相同,尤其在全局變量、函數(shù)和對象中的指向,以及通過apply、call和bind在改變綁定對象后this的指向問題,對于初學(xué)者來說很容易混淆,并因此可能導(dǎo)致程序錯誤。本文根據(jù)this在不同上下文環(huán)境中的指向問題進行分類探討,便于讀者對JavaScript中的this指向問題的理解和應(yīng)用。

2 JavaScript中的this指向分析

在JavaScript語言中,使用到this關(guān)鍵字的上下文通常包括全局變量、普通函數(shù)、構(gòu)造函數(shù)、對象函數(shù)和箭頭函數(shù),以及通過關(guān)鍵字apply、call和bind改變對象指向后this的指向。下面就不同情況下this的指向進行分析探討。

2.1 全局變量和函數(shù)中this指向

在全局變量中,this默認(rèn)指向的是window對象,此時可以省略this,也可以使用window來代替,如下面代碼所示:

var str="hello JavaScript";

function fn(){

console.log(this.str);

}

this.fn();

console.log(this);

在上面代碼中this指向就是window對象,即使在普通函數(shù)fn()中,此時this也是指向的window對象,用來獲取全局變量的值。但是在ES6以后,如果改用let來定義全局變量,此時全局變量將不再是window對象的屬性了,如下面代碼所示:

let str="hello JavaScript";

console.log(str);//hello JavaScript

console.log(this.str);//undefined

在上面代碼中,可以使用變量名str直接訪問,但是不能使用this.str來訪問,因為let定義的全局變量不再屬于window對象,此時將輸出undefined。

2.2 構(gòu)造函數(shù)中的this指向

JavaScript可以通過構(gòu)造函數(shù)來創(chuàng)建并初始化對象,只不過JavaScript沒有類定義和特殊的構(gòu)造器定義,需要程序員自己定義一個構(gòu)造函數(shù)來創(chuàng)建屬性,而所有的函數(shù)都可以被用來定義構(gòu)造函數(shù)[2]。在構(gòu)造函數(shù)中使用this,這點和其他高級語言類似,this指向的是使用new創(chuàng)建的對象,如下面代碼所示:

function Student(name,age)

{

this.name=name;

this.age=age;

}

var stu=new Student("zhangsan",15);

console.log(stu.name);//zhangsan

在上面代碼中,構(gòu)造函數(shù)中的this就指向了使用Student函數(shù)創(chuàng)建的當(dāng)前對象stu,這一點和其他的高級語言構(gòu)造函數(shù)中的this功能類似,都是指向當(dāng)前對象本身。

2.3 對象函數(shù)中的this指向

面向?qū)ο缶幊趟枷氲闹攸c在“對象”上,對象實質(zhì)上是“客觀事物”在程序設(shè)計語言中的表現(xiàn)形式[3]。在JavaScript對象中可以使用this來訪問對象的屬性和函數(shù),此時this的指向是當(dāng)前對象,但是如果對象的函數(shù)是其他全局函數(shù)的引用,那么全局函數(shù)中的this指向就可能發(fā)生改變,如下面代碼所示:

var name="zhangsan";

function show()

{

console.log(this.name);

}

var stu={

name:'lisi',

show:show

}

show();//輸出zhangsan

stu.show();//輸出lisi

在上面代碼中,如果直接調(diào)用show()函數(shù),則是輸出全局變量name的值”zhangsan”,但是在stu對象中的show函數(shù)是對全局函數(shù)show()的引用,stu.show()在執(zhí)行時show函數(shù)中的this則指向了stu對象,所以輸出“l(fā)isi”。

如果對象屬性還是一個對象,并且和父對象具有相同的屬性,那么this則指向當(dāng)前的屬性對象,如下面代碼所示:

主站蜘蛛池模板: 一本久道热中字伊人| 在线综合亚洲欧美网站| 亚洲精品成人片在线播放| 中文字幕在线观看日本| 亚洲自偷自拍另类小说| 国产在线视频福利资源站| 国产凹凸视频在线观看| 男女性午夜福利网站| 无码久看视频| 91精品亚洲| 亚洲欧美人成人让影院| 色婷婷亚洲综合五月| 国产在线日本| 国产一区在线观看无码| 久久人搡人人玩人妻精品| 亚洲一区精品视频在线| 五月天久久综合国产一区二区| 国内精品伊人久久久久7777人| 亚洲精品国产日韩无码AV永久免费网| 成人精品免费视频| 成人免费一级片| 午夜国产在线观看| 国产在线精品人成导航| 亚洲二区视频| 亚洲成人免费看| 五月天天天色| 五月婷婷激情四射| 日韩毛片免费观看| 日韩午夜福利在线观看| 亚洲色偷偷偷鲁综合| 亚洲男人在线天堂| 精品欧美一区二区三区在线| 国产精品人成在线播放| 97视频精品全国在线观看| 综合色区亚洲熟妇在线| 天堂岛国av无码免费无禁网站| 亚洲成av人无码综合在线观看| 久久精品只有这里有| 国产三级精品三级在线观看| 成人综合在线观看| 国产成人啪视频一区二区三区| 久久久久亚洲AV成人网站软件| 婷婷久久综合九色综合88| 又黄又湿又爽的视频| 亚洲自拍另类| 亚洲国产精品久久久久秋霞影院| 99在线视频免费观看| 国产精品主播| 刘亦菲一区二区在线观看| 天天躁夜夜躁狠狠躁躁88| 亚洲一区二区三区中文字幕5566| 狠狠躁天天躁夜夜躁婷婷| 欧美啪啪网| 国产色伊人| 亚洲无码日韩一区| 国产女人综合久久精品视| 这里只有精品免费视频| 国产a网站| 午夜啪啪网| 六月婷婷激情综合| 在线观看欧美精品二区| 精品综合久久久久久97超人该 | 国产精品永久不卡免费视频| 色哟哟国产精品| 四虎成人精品在永久免费| 国产成人综合久久| 国产综合色在线视频播放线视| 国产亚洲精品97在线观看 | 看国产一级毛片| 她的性爱视频| 2019年国产精品自拍不卡| 亚洲精品视频免费看| 日本午夜视频在线观看| 五月婷婷丁香色| 婷婷色在线视频| 久久国产亚洲欧美日韩精品| 亚洲国产av无码综合原创国产| 午夜免费视频网站| 青青久久91| 日韩在线第三页| 欧美在线精品一区二区三区| www.精品国产|