JavaScript中通過閉包解決只能取得包含函數中任何變量最后一個值的問題
更新時間:2010年08月12日 10:23:58 作者:
JavaScript中解決閉包只能取得包含函數中任何變量最后一個值的問題
復制代碼 代碼如下:
<script type="text/javascript">
function createArray() {
var arr = new Array();
for (var i = 0; i < 10; i++) {
arr[i] = function () {
return i;
}
}
return arr;
}
var funcs = createArray();
for (var i = 0; i < funcs.length; i++) {
document.write(funcs[i]() + "<br />");
}
//以上輸出全部是i的最后一次的值(10),即會輸出10個10,顯然這不是我們想要的
//原因:因為每個函數都保存了createArray函數的活動對象,所以他們引用的都是同一個i(按引用傳的值)
//解決方案:把按引用傳參修改為按值傳參
function createArray() {
var arr = new Array();
for (var i = 0; i < 10; i++) {
arr[i] = function (num) {
return function () {
return num;
}
} (i);//調用此匿名函數返回內部匿名函數,這里多了一步按值傳遞參數
}
return arr;
}
var funcs = createArray();
for (var i = 0; i < funcs.length; i++) {
alert(funcs[i]() + "<br />");
}
//以上輸出的為理想結果
</script>
相關文章
javascript函數的call、apply和bind的原理及作用詳解
javascript函數的call、apply和bind?本質是用來實現繼承的,專業(yè)點說法就是改變函數體內部this的指向,當一個對象沒有某個功能時,就可以用這3個來從有相關功能的對象里借用過來,文中通過代碼示例介紹的非常詳細,需要的朋友可以參考下2023-05-05