亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

深入理解Javascript中this的作用域

2019-11-20 14:16:54
字體:
來源:轉載
供稿:網友

大家在使用Javascript的時候經常被this這個家伙搞得暈頭轉向的。對大多數有OOP開發經驗的開發人員來說this是當前作用域中引用普通元素的標識符,但是在Javascript中它卻顯得古靈精怪的,因為它不是固定不變的,而是隨著它的執行環境的改變而改變。在Javascript中this總是指向調用它所在方法的對象。

舉一個簡單的例子:

復制代碼 代碼如下:

function test(){
alert(this);
}
var obj=function(){
var name='testObj';
}
obj.objTest=test;
test();
obj.objTest();

把這段代碼放到HTML中運行這個頁面,你會看到首先提示一個警告[object window],然后第二個警告。

復制代碼 代碼如下:

var obj=function(){
var name='testObj';
}

我們先定義了一個test()方法,并在方法內部調用alert()方法將this顯示出來,然后定義了一個obj函數對象,并給它加了一個私有的字段name,同時給它加了一個靜態的方法objTest(),而這個函數則直接指向test()函數。

分別調用test()和obj.objTest()方法,第一次警告框提示的是Window對象,而第二次提示的是我們定義的obj這個函數的代碼。這說明了test函數在兩次執行的時候this的值是不同的!

這就說明了當調用函數的對象不同的時候,其內部的this關鍵字指代的對象是不同的。這里需要值得注意的是Javascript是基于對象的語言,當我們的變量或者函數定義在<script></script>標簽的根下的時候其實相當于給window對象加了相應的屬性或方法,所以當我們利用function test(){}代碼定義一個函數的時候,其實相當于給window對象添加了一個新的函數,即window.test()函數。

我們可以做一個實驗:

復制代碼 代碼如下:

function test(){
alert(this);
}
alert(test===window.test);

警告框提示的將是true,這說明當我們在調用test()這個函數時相當于調用的是window.test()。所以當我們調用test()函數的時候調用這個函數的對象其實是window對象,this指代的是window對象,所以我們在alert(this)的時候彈出的警告窗口內容是[object Window]。我們將obj.objTest=test相當于把obj.objTest()指向test(),所以當我們調用obj.objTest()函數時相當于在obj調用了test()這個函數,所以現在this指代的是obj對象,提示的就是obj這個Function也就是我們看到的代碼。

說到這應該也解釋的差不多了,可能上面的例子太抽象,想象不出來它能在什么情況下用到,那我們現在就假設一個需求,做一個貼近實用一點的例子。

假設我們現在頁面中的所有超鏈接在點擊之后顏色要改為紅色,用Javascript實現。大體的思路應該是獲取頁面中所有的<a>標簽,然后遍歷所有的<a>標簽,給每一個注冊一個click事件,事件觸發后我們將它的color值設為red。

示例代碼如下:

復制代碼 代碼如下:

//改變顏色
function changeColor(){
this.style.color='#f00';
}
//初始化,給所有 a 標簽注冊事件
function init(){
var customLinks=document.getElementsByTagName('a');
for(i in customLinks){
//你也可以使用事件偵聽器方式來注冊事件
//由于要兼容IE,FF等瀏覽器可能需要更多代碼,您可以自行編寫
customLinks[i].onclick=changeColor;
}
}
window.onload=init;

將這段代碼添加到HTML文檔中,并在文檔中添加一些超鏈接,當超鏈接點擊后顏色會變成紅色,這里我們定義的changeColor()函數中this關鍵字在點擊超鏈接觸發函數的時候它指代的是當前這個超鏈接。而如果你直接調用changeColor()函數瀏覽器會報錯,提示Error: ‘this.style' is null or not an object或者undefined之類的錯誤。

不知道說到這能不能讓正在看文章的你對Javascript中的this關鍵字有了一些自己的了解呢?或者你已經不耐煩了?(:P)

其實要想真正對這個問題有更深入的理解那么必須對Javascript的作用域和作用域鏈有深入的理解。

作用域,顧名思義就是指某一屬性或方法具有訪問權限的代碼空間,簡單的說也就是這個變量或方法它在代碼中的的適用范圍。在大多數的OOP中主要有public,private,protect三種作用域,對著三種作用域在這里就不詳細解釋了,如果有OOP的經驗應該都有深入的了解。在這里我要說的是這三種作用域類型對Javascript來說幾乎是毫無意義的,因為Javascript中只有一種公共作用域,在Javascript中作用域是在函數中進行維護的。舉個例子:

復制代碼 代碼如下:

var test1='globle variable';
function example(){
var test2='example variable';
alert(test1);
alert(test2);
}
example();
alert(test1);
alert(test2);

根據我們前面解釋的,這里的test1變量相當于window的一個屬性,所以它會在整個window作用域內起作用,而test2則在example()函數的內部聲明,所以它的作用域也就維持在example()方法的內部,如果在函數的外部調用test2瀏覽器會提示出錯。而在example()內部調用test1則沒問題。

根據這個我們再舉一個例子:

復制代碼 代碼如下:

var test='globle variable';
function example(){
var test='example variable';
}
example();
alert(test);

這個例子運行會是什么結果呢?對,警告框會提示“globle variable”,因為example()函數內部的test變量其作用域只維持在內部,不會影響外部的test變量。如果我們將example()內部test變量的var關鍵字去掉呢?你可以自己試試。

說到這就有牽扯出另外一個概念,那就是作用域鏈的概念。作用域鏈就是可以確定變量值的路徑。由上面一個例子可以看出,var關鍵字是用來維護作用域鏈的,如果變量使用了var關鍵字聲明那么他就可以看作為作用域鏈的終點。同樣函數的形參的定義也會起到類似的作用。

說到這你對this這個精靈古怪的家伙有了比較清晰的認識了吧?根據它簡單的一個詮釋,this總是指向調用它所在函數的對象,根據作用域和作用域鏈,我們會很清晰的確定this的真面目。臨末尾再來一個開始那個例子的簡單變化:

復制代碼 代碼如下:

function test(){
alert(this);
}
var obj=function(){
var name='testObj';
}
obj.objTest=test;
obj.objTest2=function(){
test();
}
test();
obj.objTest();
obj.objTest2();

你猜會提示什么內容呢?你可以運行一下試試(:P);

既然this是根據調用其所在函數的對象的改變而改變的,那我們可不可以強制改變它的調用對象呢?答案是肯定的,以后的文章會介紹一下這部分內容,以及Javascript中不同類型的數據成員的實現方式,閉包等概念。

本人在學習過程中的一些經驗和心得體會,寫出來一是與大家分享另外也能檢視自己的不足,如寫的有問題還請批評指教,甚為感謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
九九热最新视频//这里只有精品| 97免费在线视频| 伊人久久久久久久久久| 亚洲另类xxxx| 国产精品扒开腿做爽爽爽男男| 国产精品视频最多的网站| 久久久久久一区二区三区| 亚洲最新av在线| 亚洲欧美日韩在线高清直播| 久久精品一本久久99精品| 国产成人福利网站| 欧美性xxxx在线播放| 久久久久久亚洲精品中文字幕| 一区二区在线免费视频| 久久九九全国免费精品观看| 国产精品美女无圣光视频| 欧美一级电影在线| 亚洲欧美福利视频| 一区二区三区四区精品| 欧美另类69精品久久久久9999| 国产精品久久久久久婷婷天堂| 国语自产精品视频在线看| 亚洲精品电影在线观看| 欧美美女操人视频| 亚洲男人天堂2024| 日韩成人高清在线| 国产精品久久久久免费a∨大胸| 北条麻妃一区二区在线观看| 一区二区成人av| 日韩欧美在线国产| 日本老师69xxx| 性欧美xxxx交| 中文字幕亚洲一区二区三区| 久久精品人人做人人爽| 一本色道久久88亚洲综合88| 亚洲免费成人av电影| 美日韩精品免费观看视频| 久久久久久亚洲| 欧美精品在线看| 亚洲a一级视频| 亚洲久久久久久久久久久| 国产成人精品一区二区在线| 国产热re99久久6国产精品| 91精品国产91久久久| 91国产中文字幕| 亚洲人成啪啪网站| 91chinesevideo永久地址| 日韩欧美在线网址| 精品国产1区2区| 日韩黄色高清视频| 亚洲一级片在线看| 国产精品视频免费在线观看| 97碰碰碰免费色视频| 欧美电影免费播放| 欧美日韩免费看| 欧美孕妇毛茸茸xxxx| 北条麻妃一区二区在线观看| 国产欧美日韩视频| 国产精品男人爽免费视频1| 国产精品日韩欧美综合| 国内成人精品一区| 亚洲午夜女主播在线直播| 国产精品1234| 久久激情视频久久| 一区二区福利视频| 热久久免费视频精品| 亚洲精品中文字| 国产精品入口免费视频一| 欧美专区在线播放| 国产在线观看精品| 国产精品久久久久久久久久久新郎| 高清欧美一区二区三区| 大伊人狠狠躁夜夜躁av一区| 国产亚洲精品久久久优势| 午夜精品久久久久久久久久久久久| 国产精品久久久av久久久| 欧美成人久久久| 国产美女久久精品| 欧美电影免费观看高清完整| 亚洲人成网在线播放| 亚洲人精品午夜在线观看| 欧美在线国产精品| 最近2019中文字幕第三页视频| 九九热这里只有精品6| 亚洲人成网站免费播放| 日韩在线观看免费全集电视剧网站| 中文在线资源观看视频网站免费不卡| 国产99视频精品免视看7| 一区二区三区国产视频| 欧美激情一区二区三区成人| 中文字幕亚洲激情| 日韩久久午夜影院| 少妇激情综合网| 欧美日韩亚洲网| 国产精品久久91| 久久福利视频导航| 麻豆国产va免费精品高清在线| www.亚洲男人天堂| 欧美色另类天堂2015| 国产精品极品尤物在线观看| 欧美激情xxxxx| 国产午夜一区二区| 国产亚洲欧美一区| 91色视频在线观看| 91av成人在线| 黑人巨大精品欧美一区二区| 亚洲精品有码在线| 欧美综合激情网| 久久久伊人日本| 亚洲自拍偷拍视频| 久久久久久久国产精品| 国产成人在线亚洲欧美| 国产欧美日韩专区发布| 国产精品∨欧美精品v日韩精品| 亚洲视频精品在线| 在线亚洲午夜片av大片| 性色av一区二区三区| 国产91网红主播在线观看| 亚洲精品久久久久久下一站| 91国内免费在线视频| 久久理论片午夜琪琪电影网| 成人福利视频在线观看| 日韩av观看网址| 九色91av视频| 在线不卡国产精品| 欧美中文在线字幕| 欧美精品国产精品日韩精品| 亚洲视频axxx| 亚洲第一网中文字幕| 日韩中文视频免费在线观看| 精品国偷自产在线| 一个人看的www久久| 日韩h在线观看| 国产精品va在线| 亚洲人精选亚洲人成在线| 日韩欧美高清视频| 国产在线视频欧美| 亚洲春色另类小说| 欧美高清视频在线观看| 欧美激情在线有限公司| 久久国产精品电影| 久久伊人精品一区二区三区| 欧美视频中文字幕在线| 亚洲免费电影一区| 97精品国产97久久久久久| 日韩精品高清在线观看| 久久精品国亚洲| 国产在线观看精品| 欧美精品videos| 一区三区二区视频| 精品高清一区二区三区| 久久久91精品国产一区不卡| 日本免费一区二区三区视频观看| 欧美成人精品一区二区三区| 成人精品在线观看| 国产精品久久一区| 国产精品扒开腿做爽爽爽男男| 亚洲欧美国产制服动漫| 国产精品久久二区| 日韩美女免费线视频| 久久久久久12| 精品在线欧美视频| 久久久中精品2020中文| 欧美大尺度电影在线观看|