5分鐘理解JavaScript中this用法分享
前言
關(guān)于JavaScript中this的用法網(wǎng)絡(luò)中已經(jīng)有較多比較詳盡的介紹,可以參考本文的參考學(xué)習(xí)資料和網(wǎng)絡(luò)。本文結(jié)合網(wǎng)絡(luò)收集整理,嘗試以一種簡易的方式闡述JavaScript中this的用法,希望對大家關(guān)于JavaScript中this用法的快速理解有所幫助。
正文
1. this用法實(shí)例
window.color = “red”;
var o = { color: “blue” };
function sayColor(){
alert(this.color);
}
sayColor(); //”red”
o.sayColor = sayColor;
o.sayColor(); //”blue”
2. this用法簡易理解
this指向哪里:
this運(yùn)行的環(huán)境(the context object),或者簡單理解為:this所在函數(shù)被調(diào)用時的當(dāng)前作用域。
一段實(shí)例代碼立刻明白:
var fun = function() {
console.log(this);
}
fun();// console: window,fun 的執(zhí)行context為window,即this所在函數(shù)(fun())被調(diào)用時的當(dāng)前作用域?yàn)閣indow。
new fun();//console: fun,fun 的執(zhí)行context為fun對象內(nèi),即this所在函數(shù)(fun())被調(diào)用時的當(dāng)前作用域?yàn)閒un對象內(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>
點(diǎn)擊這個button之后,你會發(fā)現(xiàn)按鈕的value值沒有改變。
原因:在本代碼運(yùn)行的情況下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>
點(diǎn)擊這個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關(guān)鍵字使用分析
- javascript this用法小結(jié)
- 改變javascript函數(shù)內(nèi)部this指針指向的三種方法
- javascript深入理解js閉包
- JavaScript 匿名函數(shù)(anonymous function)與閉包(closure)
- JavaScript閉包 懂不懂由你反正我是懂了
- JavaScript中的作用域鏈和閉包
- Javascript對象中關(guān)于setTimeout和setInterval的this介紹
- javascript中onclick(this)用法介紹
- Javascript之this關(guān)鍵字深入解析
- javascript閉包傳參和事件的循環(huán)綁定示例探討
- 教你如何使用firebug調(diào)試功能了解javascript閉包和this
相關(guān)文章
ES6知識點(diǎn)整理之函數(shù)對象參數(shù)默認(rèn)值及其解構(gòu)應(yīng)用示例
這篇文章主要介紹了ES6知識點(diǎn)整理之函數(shù)對象參數(shù)默認(rèn)值及其解構(gòu)應(yīng)用,結(jié)合實(shí)例形式分析了ES6函數(shù)對象參數(shù)相關(guān)使用技巧,需要的朋友可以參考下2019-04-04node.js Web應(yīng)用框架Express入門指南
這篇文章主要介紹了node.js Web應(yīng)用框架Express入門指南,從安裝到各種技術(shù)的應(yīng)用,都進(jìn)行了講解,是一篇不錯的Express入門教程,需要的朋友可以參考下2014-05-05javascript實(shí)現(xiàn)京東登錄顯示隱藏密碼
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)京東登錄顯示隱藏密碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-08-08uniapp小程序使用高德地圖api實(shí)現(xiàn)路線規(guī)劃的示例代碼
路線規(guī)劃常用于出行路線的提前預(yù)覽,我們提供4種類型的路線規(guī)劃,分別為:駕車、步行、公交和騎行,滿足各種的出行場景,這篇文章主要介紹了uniapp小程序使用高德地圖api實(shí)現(xiàn)路線規(guī)劃,需要的朋友可以參考下2023-01-01