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

首頁 > 語言 > JavaScript > 正文

javascript 閉包詳解

2024-05-06 16:22:41
字體:
來源:轉載
供稿:網友

閉包:是指有權訪問另外一個函數作用域中的變量的函數。創建閉包的常見方式就是在一個函數內部創建另外一個函數。在javascript中沒有塊級作用域,一般為了給某個函數申明一些只有該函數才能使用的局部變量時,我們就會用到閉包,我們來詳細探討下

看了一下網上閉包的概念及文章,對于這個問題,自己做一個梳理吧。

問:閉包是什么?

答:閉包是指在 JavaScript 中,內部函數總是可以訪問其所在的外部函數中聲明的參數和變量,即使在其外部函數被返回(壽命終結)了之后。

這個是我自身第一次碰到閉包的問題

 

 
  1. <!DOCTYPE HTML> 
  2. <html> 
  3. <head> 
  4. <meta charset="utf-8"/> 
  5. <title>閉包循環問題</title> 
  6. <style type="text/css"
  7. p {background:#ccc; width: 300px; height: 100px;} 
  8. </style> 
  9. </head>  
  10. <body>  
  11. <p id="p0">段落0</p>  
  12. <p id="p1">段落1</p>  
  13. <p id="p2">段落2</p>  
  14. <p id="p3">段落3</p>  
  15. <p id="p4">段落4</p>  
  16. <script type="text/javascript"
  17. forvar i=0; i<5; i++ ) {  
  18. document.getElementById("p"+i).onclick=function() {  
  19. alert(i); //訪問了父函數的變量i, 閉包  
  20. }; 
  21. }; 
  22. </script>  
  23. </body>  
  24. </html> 

如果你以前沒這么用過的話,估計也會認為單擊某個段落就會彈出這個段落相應的編號0,1,2,3,4。但實際上是都是彈出5;

對于這個問題網上已經有很多討論的博客了,他們給出了很多方法去實現彈出對應的編號。

解決方法1:將變量i保存在對應的段落的某個屬性上

 

 
  1. var pAry = document.getElementsByTagName("p");  
  2. forvar i=0; i< 5; i++ ) {  
  3. pAry[i].no = i;  
  4. pAry[i].onclick = function() {  
  5. alert(this.no);  
  6. }  
  7. }; 

解決方法2:加一層閉包,i 以函數參數形式傳遞給內層函數

 

 
  1. var pAry = document.getElementsByTagName("p");  
  2. forvar i=0; i< 5; i++ ) {  
  3. pAry[i].no = i;  
  4. pAry[i].onclick = function() {  
  5. alert(this.no);  
  6. }  
  7. }; 

對于這個產生的閉包問題,網上的說法是“變量i是以指針或者變量地址方式保存在函數中”;好吧,都和指針扯上關系了。。。。那就再探索一下吧。

探索1,返回的都是10而不是而是

 

 
  1. (function test() {  
  2. var temp =10;  
  3. for(var i=0; i< 5; i++ ){  
  4. document.getElementById("p"+i).onclick=function() {  
  5. alert(temp); //訪問了父函數的變量temp, 閉包  
  6. }; 
  7. temp=20; 
  8. })(); 

探索2,返回一次10,接下去返回的都是20

 

 
  1. (function test() {  
  2. var temp =10;  
  3. forvar i=0; i< 5; i++ ) {  
  4. document.getElementById("p"+i).onclick=function() {  
  5. alert(temp); //訪問了父函數的變量i, 閉包  
  6. if(i===1){ 
  7. alert(temp); 
  8. }; 
  9. temp=20; 
  10. })(); 

由探索的1、2,可以得出結論:函數內部訪問了與函數同級的變量,那么該變量是常駐內存的。訪問該變量實質上是訪問的是變量的地址;

接著,又看了一篇關于“JS閉包中的this對象”的文章,繼續來討論一下,this這個問題吧。

 

 
  1. // js閉包this對象1 
  2. var name = 'The Window'
  3. var object = { 
  4. name : 'My Object'
  5. getNameFunc1 : function(){ 
  6. // return this.name; 
  7. console.log(this);//object 
  8. return function(){//閉包,訪問的便是全局變量的了,this指windows 
  9. console.log(this);//windows 
  10. return this.name; //The Window 
  11. }, 
  12. getNameFunc2 : function(){ 
  13. return this.name;//訪問的是object 
  14. }, 
  15. aa:function(){ 
  16. alert(22); 
  17. }; 
  18. alert(object.getNameFunc1()());//彈出“The Window” 

問: 那么為什么匿名函數沒有取得其包含作用域的this對象呢?

答:每個函數在被調用時都會自動獲取兩個特殊變量:this 和 arguments。 內部函數在搜索這兩個變量時,指揮搜索到其活動對象為止,因此永遠不可能直接訪問外部函數中的這兩個變量。

不過通過下面的代碼可以做到這一點(直接訪問外部函數中的變量):

 

 
  1. // js閉包this對象2 
  2. var name = 'The Window'
  3. var object = { 
  4. name : 'My Object'
  5. getNameFunc : function(){ 
  6. var that = this
  7. console.log(this);//輸出的是object 
  8. return function(){ 
  9. console.log(this);//輸出的仍然是Windows 
  10. return that.name; 
  11. }; 
  12. }; 
  13. alert(object.getNameFunc()());//彈出“My Object” 

不同之處在于把this對象賦給了一個that變量,即使在函數返回之后,that也仍然引用這object,所以會返回object。

寫了那么多閉包的東西,那也順便再說一下閉包有神馬用處吧;不然,一直搗亂那閉包可真是一個不好的家伙呢。

看這樣一典型的閉包的例子:

 

 
  1. function A(){ 
  2. var a=1; 
  3. function B(){ 
  4. return a; 
  5. };  
  6. return B; 
  7. }; 
  8.  
  9. var C=A();//C取得A的子作用域B的訪問接口 
  10. console.log(C());//1 C能訪問到B的父級作用域中的變量a  

只要其他作用域能取到子作用域的訪問接口,那么其他作用域就有方法訪問該子作用域父級作用域的變量了。這樣的話,如果以后需要訪問某個函數里面的值得時候,就大大的有用咯。

這些上面的很多代碼其實也都是網上找的,我也只是把自己理解的,看的過程總結一下吧。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕av一区二区三区谷原希美| 国产婷婷色综合av蜜臀av| 久久免费少妇高潮久久精品99| 久久久久久久999精品视频| 秋霞成人午夜鲁丝一区二区三区| 欧美在线视频播放| 亚洲深夜福利网站| 精品无码久久久久久国产| 中文字幕久热精品在线视频| 国产精品久久久久久中文字| 欧美性理论片在线观看片免费| 久久国产精品99国产精| 色系列之999| 亚洲国产日韩欧美综合久久| 欧美在线中文字幕| 国产美女直播视频一区| 8090成年在线看片午夜| 久久久久国产一区二区三区| 国产成人一区二| 国产精品7m视频| 欧美日韩国产色视频| 97精品在线视频| 秋霞av国产精品一区| 国产精品视频资源| 亚洲电影在线看| 日韩在线免费视频| 91影院在线免费观看视频| 色综合伊人色综合网站| 欧美黑人视频一区| 一本久久综合亚洲鲁鲁| 欧美日韩国产一区在线| 亚洲女人天堂视频| 亚洲欧美日韩网| 亚洲一区二区三区xxx视频| 国产精品影院在线观看| 中文字幕在线看视频国产欧美在线看完整| 日韩免费观看视频| 欧美多人爱爱视频网站| 欧美亚洲激情在线| www.99久久热国产日韩欧美.com| 国产午夜精品美女视频明星a级| www.欧美精品| 亚洲一区二区三区视频播放| 欧美激情视频在线| 这里只有视频精品| 久久99热精品这里久久精品| 国产精品美乳在线观看| 在线观看欧美日韩国产| 黄网动漫久久久| 国产精品9999| 亚洲精品国产精品国自产在线| 日韩欧美黄色动漫| 欧美在线欧美在线| 午夜精品久久久久久久99黑人| 欧美性videos高清精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 91精品国产91久久久久久| 中文字幕日韩欧美在线视频| 亚洲美女喷白浆| 91精品国产99| 欧美一区二三区| 中文字幕一区二区精品| 久久男人资源视频| 欧美大人香蕉在线| 亚洲伊人一本大道中文字幕| 久久国产精品影视| 一区二区三欧美| 久久久人成影片一区二区三区观看| 国产91在线视频| 2018中文字幕一区二区三区| 国产欧美精品在线播放| 在线视频欧美性高潮| 一本一本久久a久久精品综合小说| 国产精品免费电影| 国产日本欧美一区| 亚洲国产又黄又爽女人高潮的| 精品国产一区二区三区在线观看| 欧美成人亚洲成人日韩成人| 亚洲国产一区二区三区在线观看| 国产有码在线一区二区视频| 综合国产在线视频| 激情久久av一区av二区av三区| 伊人久久大香线蕉av一区二区| 在线观看国产成人av片| 国产99久久精品一区二区| 欧美高清videos高潮hd| 欧美xxxx18国产| 亚洲人成电影网站色…| 国产中文字幕日韩| 日韩精品在线免费播放| 欧美猛男性生活免费| 国产精品一久久香蕉国产线看观看| 亚洲xxx自由成熟| 欧美黑人一区二区三区| 亚洲国产一区二区三区在线观看| 亚洲系列中文字幕| 国产精品久久久久久五月尺| 91日韩在线播放| 欧美激情免费在线| 欧美激情视频给我| 日韩专区中文字幕| 国内精品视频久久| 国产精品18久久久久久麻辣| 亚洲国产精品成人va在线观看| 日韩毛片中文字幕| 久热在线中文字幕色999舞| 91色琪琪电影亚洲精品久久| 亚洲欧美制服中文字幕| 91精品国产成人| 国产免费一区视频观看免费| 91精品国产91久久久久久最新| 视频直播国产精品| 久久久精品国产| 亚洲人成电影网站| 国产精品7m视频| 亚洲成人激情图| 国产精品久久久久久久久借妻| 欧美性受xxxx白人性爽| 亚洲国产另类久久精品| 欧美激情videos| 性亚洲最疯狂xxxx高清| 国产美女精品视频免费观看| 国产精品中文久久久久久久| 亚洲毛片在线观看.| 久久成人人人人精品欧| 色综合导航网站| 91国语精品自产拍在线观看性色| 国产精品xxxxx| 欧美性猛交丰臀xxxxx网站| 国内精品美女av在线播放| 性欧美办公室18xxxxhd| 欧美久久精品一级黑人c片| 亚洲国产一区二区三区四区| 国产精品综合网站| 亚洲天堂男人天堂| 亚洲国产成人在线播放| 91av在线影院| 欧美极品少妇xxxxⅹ喷水| 国产一区深夜福利| 91精品国产综合久久男男| 日韩中文字幕在线视频| 欧美成人精品h版在线观看| 日韩在线观看视频免费| 欧美性少妇18aaaa视频| 国产69久久精品成人| 国产成人在线视频| 午夜免费日韩视频| 91精品久久久久久| 性色av一区二区三区在线观看| 国产成人欧美在线观看| 国产一区二区三区视频免费| 欧美性视频网站| 欧美日韩国产精品一区| 日韩麻豆第一页| 欧美电影在线观看网站| 韩国精品美女www爽爽爽视频| 精品日本高清在线播放| 亚洲欧美国产日韩中文字幕| 久久精品国产69国产精品亚洲| 日本三级久久久| 国产精品久久久久久av福利| 成人在线国产精品| 久久久精品国产一区二区| 91啪国产在线|