5分鐘理解JavaScript中this用法分享
更新時間:2013年11月09日 15:15:41 作者:
這篇文章介紹了5分鐘理解JavaScript中this用法,有需要的朋友可以參考一下
前言
關于JavaScript中this的用法網(wǎng)絡中已經(jīng)有較多比較詳盡的介紹,可以參考本文的參考學習資料和網(wǎng)絡。本文結(jié)合網(wǎng)絡收集整理,嘗試以一種簡易的方式闡述JavaScript中this的用法,希望對大家關于JavaScript中this用法的快速理解有所幫助。
正文
1. this用法實例
復制代碼 代碼如下:
window.color = “red”;
var o = { color: “blue” };
function sayColor(){
alert(this.color);
}
sayColor(); //”red”
o.sayColor = sayColor;
o.sayColor(); //”blue”
2. this用法簡易理解
this指向哪里:
this運行的環(huán)境(the context object),或者簡單理解為:this所在函數(shù)被調(diào)用時的當前作用域。
一段實例代碼立刻明白:
復制代碼 代碼如下:
var fun = function() {
console.log(this);
}
fun();// console: window,fun 的執(zhí)行context為window,即this所在函數(shù)(fun())被調(diào)用時的當前作用域為window。
new fun();//console: fun,fun 的執(zhí)行context為fun對象內(nèi),即this所在函數(shù)(fun())被調(diào)用時的當前作用域為fun對象內(nèi)。
3. this用法的一個特殊情況
(1)情況:
復制代碼 代碼如下:
<input type="button" id="aButton" value="demo" onclick="demo()" />
<script type="text/javascript">
function demo() {
this.value = Math.random();
}
</script>
點擊這個button之后,你會發(fā)現(xiàn)按鈕的value值沒有改變。
原因:在本代碼運行的情況下this指向的是window對象。
復制代碼 代碼如下:
<input type="button" id="aButton" value="demo" />
<script type="text/javascript">
var button = document.getElementById("aButton");
function demo() {
this.value = Math.random();
}
button.onclick= demo;
</script>
點擊這個button之后,程序可正常執(zhí)行。
(2)原因解釋:
復制代碼 代碼如下:
<input type="button" id="aButton" value="demo" />
<script type="text/javascript">
var button = document.getElementById("aButton");
function demo() {
this.value = Math.random();
}
button.onclick= demo;
alert(button.onclick);
</script>
得到的輸出是:
復制代碼 代碼如下:
function demo() {
this.value = Math.random();
}
復制代碼 代碼如下:
<input type="button" id="aButton" value="demo" onclick="demo()" />
<script type="text/javascript">
var button = document.getElementById("aButton");
function demo() {
this.value = Math.random();
}
alert(button.onclick);
</script>
得到的輸出是:
復制代碼 代碼如下:
function onclick() {
demo();
}
您可能感興趣的文章:
- Javascript this關鍵字使用分析
- javascript this用法小結(jié)
- 改變javascript函數(shù)內(nèi)部this指針指向的三種方法
- javascript深入理解js閉包
- JavaScript 匿名函數(shù)(anonymous function)與閉包(closure)
- JavaScript閉包 懂不懂由你反正我是懂了
- JavaScript中的作用域鏈和閉包
- Javascript對象中關于setTimeout和setInterval的this介紹
- javascript中onclick(this)用法介紹
- Javascript之this關鍵字深入解析
- javascript閉包傳參和事件的循環(huán)綁定示例探討
- 教你如何使用firebug調(diào)試功能了解javascript閉包和this
相關文章
JavaScript中for..in循環(huán)陷阱介紹
for...in循環(huán)中的循環(huán)計數(shù)器是字符串,而不是數(shù)字它包含當前屬性的名稱或當前數(shù)組元素的索引,下面有個不錯的示例大家可以參考下2013-11-11
微信小程序監(jiān)聽用戶登錄事件的實現(xiàn)方法
這篇文章主要介紹了微信小程序監(jiān)聽用戶登錄事件的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11
一定有你會用到的JavaScript一行代碼實用技巧總結(jié)
這篇文章主要為大家介紹了一定有你會用到的JavaScript一行代碼總結(jié),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-07-07
JS繪圖Flot如何實現(xiàn)動態(tài)可刷新曲線圖
這篇文章主要介紹了JS繪圖Flot如何實現(xiàn)動態(tài)可刷新曲線圖,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-10-10
javascript 實現(xiàn)的類似hao123的多郵箱登錄效果
javascript 實現(xiàn)的類似hao123的多郵箱登錄效果...2007-08-08
js實現(xiàn)同一頁面可多次調(diào)用的圖片幻燈切換效果
這篇文章主要介紹了js實現(xiàn)同一頁面可多次調(diào)用的圖片幻燈切換效果,可實現(xiàn)在同一頁面中多次調(diào)用幻燈切換效果,非常具有實用價值,需要的朋友可以參考下2015-02-02

