色婷婷狠狠18禁久久YY,CHINESE性内射高清国产,国产女人18毛片水真多1,国产AV在线观看

javascript 閉包 this

孟夢涵1年前7瀏覽0評論

JavaScript是一種基于對象和面向?qū)ο蟮哪_本語言,它的最大特點就是靈活性和可擴展性。而在JavaScript中,閉包和this兩個概念是很容易被混淆和理解錯誤的。本文將從閉包和this兩個方面入手,詳細解釋二者的作用和使用。

JavaScript閉包的概念和作用

JavaScript閉包是指函數(shù)在定義時,能夠訪問自身函數(shù)外部的變量,在函數(shù)被調(diào)用時,函數(shù)內(nèi)部依然能夠訪問到自身函數(shù)定義時的環(huán)境,簡單點說,就是在函數(shù)內(nèi)部創(chuàng)建一個私有作用域,從而保護函數(shù)內(nèi)部的變量不受外部影響。下面是一個閉包的簡單示例:

function outer() {
var count = 0;
function inner() {
count++;
console.log(count);
}
return inner;
}
var addOne = outer();
addOne(); // 1
addOne(); // 2

這個例子中,函數(shù)outer()返回了函數(shù)inner(),而函數(shù)inner()又能夠訪問到outer()中的變量count,此時,每次調(diào)用addOne()函數(shù),count都會先加一再輸出。這就是一個閉包的應(yīng)用。

this關(guān)鍵字在JavaScript中的作用和使用

this是JavaScript中比較特殊的一個關(guān)鍵字,因為它的值是動態(tài)的,指向當(dāng)前函數(shù)執(zhí)行時所處的上下文環(huán)境。具體來說,在全局環(huán)境中,this指向的是window對象;在函數(shù)里面,this指向的是調(diào)用這個函數(shù)的對象。下面是一個this的例子:

var person = {
name: '張三',
age: 18,
sayHello: function() {
console.log('我叫' + this.name + ',今年' + this.age + '歲。');
}
}
person.sayHello(); // 我叫張三,今年18歲。

在這個例子中,sayHello函數(shù)中引用了this關(guān)鍵字,this指向的是person對象,因此在調(diào)用person的sayHello方法時,this.name指向的就是person的姓名屬性,this.age指向的就是person的年齡屬性。這也是this關(guān)鍵字在JavaScript中使用的一個重要應(yīng)用。

閉包和this的實例

有時候在JavaScript中,我們需要使用閉包和this關(guān)鍵字進行程序開發(fā),但由于閉包和this使用容易出現(xiàn)問題,因此我們需要格外注意。下面的代碼就展示了一個使用閉包和this關(guān)鍵字開發(fā)的小例子,我們看看其中的問題在哪里:

var buttons = document.getElementsByTagName('button');
for (var i = 0; i < buttons.length; i++) {
buttons[i].onclick = function() {
alert('你點擊了第' + i + '個按鈕。');
}
}

這段代碼的意思很簡單,就是將頁面的所有按鈕OnClick事件綁定到一個函數(shù)里面,在點擊一個按鈕時,彈出當(dāng)前按鈕的序號。但問題是,無論我們點擊哪一個按鈕,彈出的序號都是按鈕的總數(shù)。這是什么原因呢?問題的關(guān)鍵就在于,雖然我們在onclick函數(shù)里面通過閉包存儲了當(dāng)前的i值,但是我們在打印提示框時再去獲取i值的時候,i已經(jīng)被加到最大值了,因此無論點擊哪一個按鈕都是輸出最大值。正確的寫法應(yīng)該是:

var buttons = document.getElementsByTagName('button');
for (var i = 0; i < buttons.length; i++) {
(function(i) {
buttons[i].onclick = function() {
alert('你點擊了第' + i + '個按鈕。');
}
})(i);
}

這里我們在onclick事件中用一個立即執(zhí)行的匿名函數(shù)將當(dāng)前的i值保存到閉包中,這樣無論點擊哪一個按鈕,都能夠正確輸出當(dāng)前的按鈕序號。

總結(jié)

在JavaScript中,閉包和this關(guān)鍵字是程序開發(fā)中比較常用的概念和關(guān)鍵字。對于閉包,我們可以將函數(shù)內(nèi)部變量設(shè)置為私有變量,防止變量被外部污染;對于this,我們可以通過this將當(dāng)前的執(zhí)行環(huán)境與對象進行綁定,以便引用對象的屬性或方法。理解閉包和this的使用,可以幫助我們更好地開發(fā)出JavaScript程序,提高開發(fā)效率。