亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript閉包函數訪問外部變量的方法

2019-11-20 14:14:10
字體:
來源:轉載
供稿:網友

閉包是指有權訪問另一個函數作用域中的變量的函數,但作用域的配置機制有一個需要注意的地方,即閉包只能取得包含函數中任何變量的最后一個值。

如以下案例:

function create(){    var arr = new Array();       for (var i=0; i<10; i++){        arr[i] = function(){            return i;        };      }     return arr;} var c_arr = create(); for(var i=0; i<c_arr.length;i++){    document.write("c_arr["+i+"] = "+c_arr[i]()+"<br />");    }

執行結果:

JS閉包

表面上看,似乎每個函數返回的i值都不相同,比如c_arr[0]的值應該是0,c_arr[1]的值應該是1,以此類推。可結果每個函數都返回10。為什么呢?

因為每個函數的作用域鏈中保存著create()函數的活動對象,所以它們引用的都是同一個變量i。當for循環結束以后,i的值也就變成10了,此時每個函數都引用保存變量i的同一個變量對象。

 

我們可以通過創建另一個域名函數強制讓閉包的行為符合預期,使每個位置對應相應的值。

function create(){    var arr = new Array();       for (var i=0; i<10; i++){        arr[i] = function(num){            return function(){                return num;             };        }(i);       }     return arr;} var c_arr = create(); for(var i=0; i<c_arr.length;i++){    document.write("c_arr["+i+"] = "+c_arr[i]()+"<br />");    }

執行結果:

JS閉包

定義了一個匿名函數,并立即執行匿名函數的機過賦給數組,這里匿名函數有一個參數num,也就是最終的函數要返回的值。在調用每個函數時我們傳入變量i。由于函數參數是按值傳遞的,所以就會將變量i的當前值賦值給參數num。而在這個匿名函數內部,又創建并返回了一個訪問num的閉包,這樣一來arr數組中的每個函數都有自己num變量的一個副本,因此就可以返回各自不同的數值了。

經典例子

我們再來看一個經典的例子,假設頁面有一組button標簽,我們利用腳本給這組button標簽綁定單擊事件,并且單擊時能彈出這是第幾個標簽。

<meta charset="utf-8" /> <button>第一個</button><button>第二個</button><button>第三個</button><button>第四個</button>  <script type="text/javascript"> var obj = document.getElementsByTagName('button');for(var i=0;i<obj.length;i++){    obj[i].onclick = function(){        alert(i);    };  } </script>

點擊每一個按鈕結果

JS閉包

表面上看,似乎單擊每一個標簽應該彈出不同數字

第一個應該彈出0;

第二個應該彈出1;

以此類推。

可結果是所有按鈕都彈出4,顯然這不是我們想要的結果。

我們把程序改一下

<meta charset="utf-8" /> <button>第一個</button><button>第二個</button><button>第三個</button><button>第四個</button>  <script type="text/javascript"> var obj = document.getElementsByTagName('button');for(var i=0;i<obj.length;i++){    obj[i].onclick = function(num){        return function(){            alert(num);        }           }(i);       } </script>

點擊第二個

JS閉包

點擊第四個

JS閉包

我們只需要在函數內建立一個匿名函數,同以上案例同理。即可實現匿名函數捕獲外部變量i,結果每個按鈕彈的i值都不同。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产不卡av在线| 欧洲成人午夜免费大片| 欧美最顶级的aⅴ艳星| 韩国精品美女www爽爽爽视频| 亚洲小视频在线观看| 国产欧美久久久久久| 亚洲女人天堂视频| 成人乱色短篇合集| 91精品久久久久久久久中文字幕| 亚洲欧美日本伦理| 国产91精品青草社区| 91国产中文字幕| 伊人一区二区三区久久精品| 日韩欧美在线视频免费观看| 欧美一级在线亚洲天堂| 日本精品性网站在线观看| 久久精品国亚洲| 久久欧美在线电影| 欧美专区国产专区| 国产精品丝袜高跟| 国产视频观看一区| 欧美性xxxx极品hd满灌| 国产精品美女免费| 欧美乱人伦中文字幕在线| 日韩视频在线一区| 亚洲欧美另类在线观看| 久久久久五月天| 成人黄色免费片| 亚洲男人天堂2019| 欧美电影在线观看完整版| 国产精品福利小视频| 精品久久久精品| 国产精品精品视频一区二区三区| 欧美裸体xxxx极品少妇软件| 黑人巨大精品欧美一区免费视频| 欧美自拍视频在线观看| 狠狠色香婷婷久久亚洲精品| 色狠狠av一区二区三区香蕉蜜桃| 日韩国产一区三区| 狠狠躁夜夜躁人人爽超碰91| 日韩美女免费视频| 全球成人中文在线| 色樱桃影院亚洲精品影院| 色悠久久久久综合先锋影音下载| 国产精品白丝av嫩草影院| 亚洲网址你懂得| 色樱桃影院亚洲精品影院| 日韩一区二区福利| 亚洲区一区二区| 最好看的2019年中文视频| 国产精品国语对白| 国产精品久久久久aaaa九色| 欧美黄色小视频| 日韩中文字幕在线视频| 超碰精品一区二区三区乱码| 91精品久久久久久久久中文字幕| 8050国产精品久久久久久| 亚洲精品在线看| 亚洲欧美在线看| 精品日本高清在线播放| 亚洲第一福利网| 2020欧美日韩在线视频| 成人网中文字幕| 久久九九全国免费精品观看| 这里只有精品视频| 91精品国产综合久久香蕉的用户体验| 久久久久久久一| 成人国产在线激情| 1769国产精品| 亚洲第一免费网站| 亚洲国产精品系列| 丝袜美腿亚洲一区二区| 97免费在线视频| 日韩欧美在线国产| 国产999在线| 91精品国产成人www| 91超碰中文字幕久久精品| 久久亚洲影音av资源网| 亚洲性日韩精品一区二区| 亚州成人av在线| 黄色一区二区在线| 亚洲无线码在线一区观看| 久久久国产成人精品| 久久99精品视频一区97| 91sao在线观看国产| 亚洲国产精品成人精品| 欧美在线观看日本一区| 国产精品美女免费视频| 国内精品久久久久伊人av| 91国在线精品国内播放| 91地址最新发布| 日本韩国在线不卡| 国产91在线视频| 亚洲精品视频免费在线观看| 成人国产在线视频| 亚洲精品在线91| 国产精品成人va在线观看| 亚洲伊人成综合成人网| 国产一区二区在线免费| 日本免费一区二区三区视频观看| 亚洲专区在线视频| 欧美成人h版在线观看| 成人免费观看网址| 91久久中文字幕| 在线观看国产成人av片| 国产精品高潮粉嫩av| 欧美交受高潮1| 国产一区二区三区中文| www.亚洲免费视频| 国产一区二区三区18| 色在人av网站天堂精品| 午夜精品一区二区三区av| 日韩精品一区二区视频| 国产一区二区三区丝袜| 久久影视免费观看| 久久99热精品这里久久精品| 精品久久久久久久久久久久| 亚洲精品国产精品国产自| 日韩电影免费观看在线观看| 日产精品99久久久久久| 亚洲精品自拍偷拍| 亚洲欧美综合v| 亚洲黄色www| 日韩在线精品视频| 精品视频在线观看日韩| 亚洲人成欧美中文字幕| 亚洲r级在线观看| 亚洲成人aaa| 亚洲精品久久在线| 欧美日韩aaaa| 国产视频观看一区| 国产精品video| 国产精品99久久99久久久二8| 精品亚洲国产视频| 日韩视频―中文字幕| 在线视频国产日韩| 国产精品网站入口| 中文日韩在线视频| 国产亚洲精品成人av久久ww| 91精品久久久久久久久久| 国产精品免费一区二区三区都可以| 久久久在线免费观看| 国产丝袜精品第一页| 国产成人精品一区二区在线| 日韩欧美一区视频| 亚洲曰本av电影| 成人综合国产精品| 久久久久久久久久久网站| 久久久久亚洲精品| 国产日韩精品视频| 国产成人亚洲综合| 日韩av在线资源| 亚洲视频免费一区| 久久精品中文字幕免费mv| 亚洲国产女人aaa毛片在线| 亚洲精品www| 久久精品国产成人精品| 国产在线拍揄自揄视频不卡99| 亚洲国内精品视频| 成人a在线观看| 国产欧美日韩最新| 免费av一区二区| 国产精品女人网站| 久色乳综合思思在线视频|