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

首頁 > 語言 > JavaScript > 正文

js閉包實例匯總

2024-05-06 16:10:30
字體:
來源:轉載
供稿:網友
本文是通過實例來幫助大家深刻理解js閉包,是篇非常不錯的文章,這里推薦給大家,有需要的小伙伴可以參考下
 
 

Js閉包
閉包前要了解的知識
1. 函數作用域
(1).Js語言特殊之處在于函數內部可以直接讀取全局變量

 

復制代碼代碼如下:

<script type="text/javascript">
var n=100;
function parent(){
  alert(n);
}
parent();//100
</script>

 

如果在php里

 

復制代碼代碼如下:

<?php
$n=100;
function parent(){
  echo $n;
}
parent();//會報錯 n未定義
?>

 

(2).在函數外部無法讀取函數內的局部變量

 

復制代碼代碼如下:

<script type="text/javascript">
function parent(){
  var m=50;
}
parent();
alert(m);//報錯 m未定義
</script>

 

注意函數內部聲明變量時一定要加var,否則就聲明了一個全局變量

 

復制代碼代碼如下:

function parent(){
m=50;
}
parent();
alert(m);//50

 

//當然在php里更是如此了,

 

復制代碼代碼如下:

<?php
function parent(){
  global $m;//全局 ,定義與賦值要分開
  $m=50;
}
parent();
echo $m;//50
?>
//沒global的話,一樣會報沒定義的錯誤

 

有時,需要得到函數內部的的局部變量,就需要變通的方法實現利用js變量作用域的特點,如在函數內部定義子函數,對于子函數來說,父函數就是它的全局,子函數可以訪問父函數里的變量(對于整個js代碼來說又是局部變量)

 

復制代碼代碼如下:

<script type="text/javascript">
function parent(){
   var m=50;
   function son(){
        alert(m);
   }
   return son;
}
var s=parent();//將結果保存在全局里
s();//50
</script>

 

Parent內部所有局部變量對其子函數來說都是可見的,但其子函數內的局部變量對其父函數是不可見的,這就是js特有的鏈式作用域結構,子對象會一級一級地向上查找所有父對象的變量,父對象的所有變量對子對象都是可見的,反之不成立!上面的son函數就是閉包
有些同學可能這樣

 

復制代碼代碼如下:

function parent(){
   var m=50;
   function son(){
        alert(m);
   }
}
parent();
son()//會報 函數son未定義

 

注意 在javascript里,在函數里聲明的函數都是局部的,函數運行完后就釋放了
注意這點與php的區別

 

復制代碼代碼如下:

<?php
function parent(){
  function son(){
      $m=50;
      echo $m;
  }
}
parent();
son();//輸出50 不會報錯
?>

 

閉包

函數內部定義函數,連接函數內部和外部的橋梁
閉包的作用有2個:
一是前面提到的讀取函數內部的變量,
二是讓這些變量的值保存在內存中,實現數據共享
下面是幾個閉包的例子

 

復制代碼代碼如下:

<script type="text/javascript">
var cnt=(function(){
    var i=0;
    return function(){
        alert(i);
        i++;
    }
})();
cnt();//0
cnt();//1
cnt();//2
cnt();//3

 

</script>

 

把匿名函數的執行結果(即對里面子函數的聲明賦給全局變量cut),i就保存在內存里了
執行cut()時就直接從內存取值了,i只有cnt()函數才能調用,直接alert(i)是不行的
還可以向閉包內傳參

 

復制代碼代碼如下:

var cnt=(function(num){
return function(){
    alert(num);
    num++;
  }
})(5);
cnt();//5
cnt();//6
cnt();//7
//當然還可以調用時傳參
var cnt=(function(){
    var i=0;
return function(num){
    num+=i;
    alert(num);
    i++;
  }
})();
cnt(1);//1
cnt(2);//3
cnt(3);//5

 

為了對閉包有更好的理解,我們看以下代碼
比如我想返回一個數組,數組里面有5個函數,第一個函數彈出0,第二個彈出1...  
代碼如果這樣寫

 

復制代碼代碼如下:

function box(){
  var arr=[];
  for(i=0;i<5;i++){
      arr=function(){return i;}
    }
return arr;   
}
var a=box();
alert(a);//包含五個函數體的數組
alert(a[0]());
alert(a[1]());

 

彈出的函數體
function(){return i;}    }
最后這個i是4,之后++成為5
For循環停止
發現均彈出5,明顯不符合我們的要求

解決方案1
自我即時執行里面的函數

 

復制代碼代碼如下:

function box(){
  var arr=[];
  for(i=0;i<5;i++){
      arr=(function(num){return i;})(i);
    }
return arr;   
}
var a=box();
for(var i=0;i<a.length;i++){
  alert(a);
}

 

但是我們發現 返回的數組里的元素是函數執行的結果,但我們想要的是函數有得升級我們的代碼

解決方案2
閉包實現

 

復制代碼代碼如下:

function box(){
var arr=[];
        for(var i=0;i<5;i++){

 

                 arr=(function(num){
                     return function(){return num;}
                 })(i);

         }
return arr;         
}

var arr=box();

for(var i=0;i<5;i++){

    alert(arr());//0,1,2,3,4
}

 

關鍵代碼

 

復制代碼代碼如下:

arr=(function(num){ 
         return function(){return num;}
})(i);

 


i=0 時 
arr[0]=(function(num){return function(){return num;}})(0);

1時


arr[1]=(function(num){return function(){return num;}})(1);  

 

  以上就是閉包的好處!非常簡單實用吧。


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

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩在线观看免费高清| 日韩美女中文字幕| 亚洲天堂男人的天堂| 欧美视频中文在线看| 一区二区三欧美| 国产在线观看精品一区二区三区| 国产主播喷水一区二区| 亚洲自拍在线观看| 热re99久久精品国产66热| 在线亚洲国产精品网| 日韩电影视频免费| 亚洲天堂第二页| 日韩欧美在线字幕| 亚洲护士老师的毛茸茸最新章节| 国产欧美精品久久久| 国产精品一区二区久久久久| 亚洲第一偷拍网| 欧美激情综合色综合啪啪五月| 欧美xxxx18性欧美| 欧美亚洲另类制服自拍| 欧美性猛交xxxx乱大交| 色偷偷88888欧美精品久久久| 91精品国产高清久久久久久| 欧美日韩在线观看视频| 日韩成人网免费视频| 亚洲精品网站在线播放gif| 国产精品久久久久久av下载红粉| 日韩成人在线视频观看| 久热爱精品视频线路一| 亚洲精品720p| 欧美综合激情网| 久久精品视频99| 在线观看日韩视频| 欧美午夜电影在线| 亚洲男人天堂网| 日韩成人久久久| 综合网日日天干夜夜久久| 亚洲欧美在线一区二区| 久久av红桃一区二区小说| 日本精品免费观看| 亚洲天堂网站在线观看视频| 国产成人+综合亚洲+天堂| 国产欧美一区二区三区在线| 久久精品国产亚洲7777| 亚洲国产婷婷香蕉久久久久久| 一级做a爰片久久毛片美女图片| 草民午夜欧美限制a级福利片| 69国产精品成人在线播放| wwwwwwww亚洲| 日韩在线免费观看视频| 一夜七次郎国产精品亚洲| 91九色单男在线观看| 成人中文字幕+乱码+中文字幕| 这里只有精品视频在线| 欧美丰满片xxx777| 午夜精品久久久久久久男人的天堂| 亚洲美腿欧美激情另类| 亚洲精品一区二区在线| 欧美国产在线视频| 亚洲欧洲一区二区三区久久| 色婷婷综合久久久久中文字幕1| 精品国产91乱高清在线观看| 欧美高清视频在线播放| 国产精品美女www| 久久久av亚洲男天堂| 国产精品一久久香蕉国产线看观看| 久久久久久久久电影| 欧美激情视频网| 亚洲第一精品夜夜躁人人躁| 黑人精品xxx一区| 欧美中文字幕视频| 精品调教chinesegay| 久久久国产91| 午夜精品福利在线观看| 欧美激情女人20p| 久久久视频在线| 亚洲在线视频福利| 成人网在线免费观看| 亚洲精品98久久久久久中文字幕| 在线观看日韩专区| 久久久久久久国产| 懂色av影视一区二区三区| 日本成人精品在线| 91精品久久久久久久久久入口| 久久黄色av网站| 欧美色播在线播放| 影音先锋欧美在线资源| 日韩在线精品视频| 国产精品爱啪在线线免费观看| 久久久久九九九九| 精品国产依人香蕉在线精品| 亚洲精品中文字幕有码专区| 国产精品久久久久久久久久久新郎| 日韩在线观看免费av| 在线观看欧美视频| 欧美极品少妇xxxxⅹ免费视频| 日韩亚洲欧美成人| 国产精品成av人在线视午夜片| 91爱视频在线| 国产精品午夜一区二区欲梦| 成人精品在线视频| 亚洲精品久久久一区二区三区| 国产精品久久久久999| 久久久久久中文| 国产精品流白浆视频| 亚洲精品美女在线观看播放| 久久久久久久久网站| 欧美日韩一区二区在线播放| 亚洲老板91色精品久久| 欧美精品久久久久久久| 亚洲第一福利在线观看| 精品久久久久久久久久久| 国模私拍一区二区三区| 色婷婷亚洲mv天堂mv在影片| 2019av中文字幕| 日本成人黄色片| 精品中文字幕在线2019| 亚洲欧美精品一区二区| 午夜精品一区二区三区视频免费看| 欧美大片大片在线播放| 中文字幕综合一区| 国产mv免费观看入口亚洲| 97不卡在线视频| 91po在线观看91精品国产性色| 欧美大学生性色视频| 国产精品日日摸夜夜添夜夜av| 久久久日本电影| 亚洲精品国产品国语在线| 性欧美暴力猛交69hd| 日韩在线视频国产| 国产精品久久久av| 欧美电影免费观看电视剧大全| 亚洲成色777777女色窝| 亚洲成色777777女色窝| 成人黄色在线免费| 国产亚洲精品久久久久久777| 日本aⅴ大伊香蕉精品视频| 国产成+人+综合+亚洲欧洲| 日韩中文第一页| 日韩av在线网| 日韩少妇与小伙激情| xxxx欧美18另类的高清| 欧美一级片免费在线| 久久久91精品| 亚洲欧美激情另类校园| 青青草国产精品一区二区| 2019中文字幕全在线观看| 国产精品成av人在线视午夜片| 中文字幕亚洲欧美在线| 疯狂做受xxxx高潮欧美日本| 国产精品久久久久不卡| 日韩视频在线免费观看| 欧美中文在线视频| 久99久在线视频| 欧美日韩国产综合新一区| 精品欧美一区二区三区| 日本免费久久高清视频| 久久99精品视频一区97| 久久久精品亚洲| 国产精品青青在线观看爽香蕉| 欧美日韩加勒比精品一区| 亚洲精品黄网在线观看| 国产欧美va欧美va香蕉在| 在线中文字幕日韩|