- 相關(guān)推薦
JavaScript中this的用法步驟
關(guān)于JavaScript中this的用法網(wǎng)絡(luò )中已經(jīng)有較多比較詳盡的介紹,可以參考本文的參考學(xué)習資料和網(wǎng)絡(luò )。本文結合網(wǎng)絡(luò )收集整理,嘗試以一種簡(jiǎn)易的方式闡述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用法簡(jiǎn)易理解
this指向哪里:
this運行的環(huán)境(the context object),或者簡(jiǎn)單理解為:this所在函數被調用時(shí)的當前作用域。
一段實(shí)例代碼立刻明白:
復制代碼 代碼如下:
var fun = function() {
console.log(this);
}
fun();// console: window,fun 的執行context為window,即this所在函數(fun())被調用時(shí)的當前作用域為window。
new fun();//console: fun,fun 的執行context為fun對象內,即this所在函數(fun())被調用時(shí)的當前作用域為fun對象內。
3. this用法的一個(gè)特殊情況
。1)情況:
復制代碼 代碼如下:
function demo() {
this.value = Math.random();
}
點(diǎn)擊這個(gè)button之后,你會(huì )發(fā)現按鈕的value值沒(méi)有改變。
原因:在本代碼運行的情況下this指向的是window對象。
復制代碼 代碼如下:
var button = document.getElementById("aButton");
function demo() {
this.value = Math.random();
}
button.onclick= demo;
點(diǎn)擊這個(gè)button之后,程序可正常執行。
。2)原因解釋?zhuān)?/p>
復制代碼 代碼如下:
var button = document.getElementById("aButton");
function demo() {
this.value = Math.random();
}
button.onclick= demo;
alert(button.onclick);
得到的輸出是:
復制代碼 代碼如下:
function demo() {
this.value = Math.random();
}
復制代碼 代碼如下:
var button = document.getElementById("aButton");
function demo() {
this.value = Math.random();
}
alert(button.onclick);
得到的輸出是:
復制代碼 代碼如下:
function onclick() {
demo();
}
【JavaScript中this的用法步驟】相關(guān)文章:
Javascript的this用法簡(jiǎn)述08-15
Javascript函數的定義和用法分析08-15
javascript分析運算符用法08-07
JavaScript中的with關(guān)鍵字07-24
在Java中執行JavaScript代碼07-14
JavaScript中常見(jiàn)的字符串操作函數及用法07-24
抽象語(yǔ)法樹(shù)在JavaScript中的應用08-18
JavaScript中的三種對象10-24