中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

深入理解Javascript中this的作用域
來源:易賢網 閱讀:1315 次 日期:2014-08-15 14:47:23
溫馨提示:易賢網小編為您整理了“深入理解Javascript中this的作用域”,方便廣大網友查閱!

大家在使用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中不同類型的數據成員的實現方式,閉包等概念。

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

更多信息請查看IT技術專欄

更多信息請查看網絡編程
易賢網手機網站地址:深入理解Javascript中this的作用域
由于各方面情況的不斷調整與變化,易賢網提供的所有考試信息和咨詢回復僅供參考,敬請考生以權威部門公布的正式信息和咨詢為準!
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網

中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
中文字幕精品一区二区三区精品| 久久毛片高清国产| 日韩欧美久久一区| 久久精品国产一区二区三| 日韩视频一区在线观看| 国产盗摄精品一区二区三区在线| 国产日韩欧美麻豆| 欧美自拍偷拍一区| 久久99精品一区二区三区| 欧美极品另类videosde| 91福利国产精品| 久久99精品久久久久久久久久久久 | 又紧又大又爽精品一区二区| 欧美人牲a欧美精品| 韩国精品在线观看| 伊人色综合久久天天| 欧美大胆一级视频| 色哟哟一区二区三区| 国产在线一区观看| 亚洲va天堂va国产va久| 国产精品三级av在线播放| 3751色影院一区二区三区| 不卡的看片网站| 麻豆精品国产传媒mv男同| 亚洲人妖av一区二区| 欧美成va人片在线观看| 在线免费观看日韩欧美| 国产福利一区二区三区| 石原莉奈一区二区三区在线观看| 国产精品无码永久免费888| 日韩三级电影网址| 欧美日韩高清一区二区三区| www.亚洲人| 国产成人一区在线| 精一区二区三区| 琪琪久久久久日韩精品| 偷拍一区二区三区四区| 一区二区三区在线免费| 欧美高清一级片在线观看| 精品sm捆绑视频| 日韩视频永久免费| 制服丝袜在线91| 欧美色区777第一页| 91丝袜呻吟高潮美腿白嫩在线观看| 国产一区在线精品| 极品少妇一区二区三区精品视频| 日本视频中文字幕一区二区三区| 亚洲综合免费观看高清完整版| 日本一区二区三区视频视频| 国产三级精品三级| 国产人伦精品一区二区| 久久精品欧美一区二区三区麻豆| 欧美大尺度电影在线| 精品国产髙清在线看国产毛片| 日韩欧美aaaaaa| 亚洲精品一区二区在线观看| 欧美日韩高清一区二区三区| 久久综合国产精品| 欧美精品777| 欧美专区在线观看一区| 91免费国产在线| 色综合一区二区| 色中色一区二区| 97se狠狠狠综合亚洲狠狠| 99久久免费视频.com| 99久久精品国产导航| 色天天综合色天天久久| 欧美日韩国产精品自在自线| 欧美网站一区二区| 欧美日韩国产在线播放网站| 91精品国产入口在线| 欧美一区午夜视频在线观看| 久久精品噜噜噜成人av农村| 三级不卡在线观看| 亚洲精品精品亚洲| 91香蕉视频黄| 国产一区视频在线看| 日韩高清不卡一区| 日本网站在线观看一区二区三区| 亚洲成精国产精品女| 奇米影视一区二区三区| 激情深爱一区二区| 粉嫩在线一区二区三区视频| 91小视频在线免费看| 欧美精品v国产精品v日韩精品| 欧美成人在线直播| 国产精品每日更新在线播放网址| 亚洲色图一区二区| 日韩国产精品久久久| 国产成人免费视频精品含羞草妖精 | 久久久91精品国产一区二区精品 | 亚洲精品中文在线影院| 亚洲成人一区在线| 国产精品一区一区三区| 在线精品视频免费播放| 久久久综合精品| 亚洲国产成人va在线观看天堂| 国产一区二区0| 欧美群妇大交群中文字幕| 欧美激情在线看| 日韩成人免费电影| 色综合久久久久综合99| 久久久综合视频| 天天影视涩香欲综合网| eeuss鲁一区二区三区| 91精品麻豆日日躁夜夜躁| 日韩美女视频19| 国产乱码一区二区三区| 91精品在线免费| 夜夜嗨av一区二区三区四季av | 久久99精品国产麻豆婷婷| 91国模大尺度私拍在线视频| 国产欧美一区二区三区网站| 日韩av电影天堂| 欧美亚洲丝袜传媒另类| 成人免费一区二区三区在线观看| 黑人巨大精品欧美一区| 8x8x8国产精品| 亚洲午夜免费视频| 在线免费观看视频一区| 亚洲男人电影天堂| av在线这里只有精品| 亚洲国产成人午夜在线一区| 久久国产成人午夜av影院| 日韩一区二区三区三四区视频在线观看| 亚洲精品日日夜夜| 色激情天天射综合网| 亚洲六月丁香色婷婷综合久久| 不卡av免费在线观看| 国产精品久久毛片a| 成年人午夜久久久| 日韩一区欧美小说| 色婷婷激情一区二区三区| 亚洲乱码精品一二三四区日韩在线 | 欧美视频一区二区三区四区| 亚洲黄网站在线观看| 欧美在线观看一二区| 亚洲综合丁香婷婷六月香| 在线亚洲一区二区| 一区二区三区**美女毛片| 欧美色综合影院| 日产国产欧美视频一区精品| 欧美不卡在线视频| 高清成人在线观看| 亚洲精选视频在线| 欧美一区2区视频在线观看| 久久国内精品自在自线400部| 久久久久久久网| av福利精品导航| 亚洲一卡二卡三卡四卡五卡| 日韩一区二区在线看| 国产精品一区免费视频| 国产精品久久看| 欧美日高清视频| 精品一区二区三区欧美| 国产精品日产欧美久久久久| 成人国产一区二区三区精品| 亚洲一区在线观看网站| 精品国产乱码久久久久久夜甘婷婷 | 亚洲一区二区高清| 日韩欧美国产三级| 成人黄色片在线观看| 亚洲一区二区av电影| 精品精品国产高清a毛片牛牛| 成人一区二区三区视频在线观看| 中文字幕永久在线不卡| 911精品产国品一二三产区| 国产精品88av| 丝袜美腿亚洲一区二区图片| 久久众筹精品私拍模特| 欧美亚洲禁片免费| 国产成人精品影视| 午夜不卡在线视频| 亚洲欧洲在线观看av| 精品久久久久久久久久久久久久久久久| www.欧美.com| 九九精品一区二区| 亚洲高清在线精品| 最新欧美精品一区二区三区| 日韩欧美亚洲另类制服综合在线 | 欧美一区二区三区思思人| 成人三级伦理片| 日韩精品亚洲一区| 亚洲精品久久久久久国产精华液| 亚洲精品一线二线三线| 在线成人高清不卡| 色欧美日韩亚洲| 成人av电影免费观看| 国产真实乱子伦精品视频| 偷窥国产亚洲免费视频| 亚洲欧美另类综合偷拍| 国产欧美精品区一区二区三区| 制服丝袜亚洲精品中文字幕| 在线观看国产一区二区| 91亚洲国产成人精品一区二三 | 亚洲日本青草视频在线怡红院 | 2020日本不卡一区二区视频| 欧美日韩免费观看一区二区三区| 成人精品在线视频观看| 国产成人亚洲综合色影视|