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

首頁 > 編程 > JavaScript > 正文

js閉包實例匯總

2019-11-20 13:56:34
字體:
來源:轉載
供稿:網友

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
国产日韩av高清| 亚洲一区二区三区xxx视频| 宅男66日本亚洲欧美视频| 欧美激情按摩在线| 国产欧美一区二区三区久久人妖| 亚洲美女精品成人在线视频| 亚洲电影免费观看| 欧美俄罗斯乱妇| 日本精品久久久| 久久精品一本久久99精品| 国产精品1234| 色综久久综合桃花网| 亚洲国产精品美女| 久久91精品国产| 亚洲综合小说区| 日韩av一区在线观看| 91老司机精品视频| 亚洲天堂av综合网| 欧美电影在线观看网站| 日本精品性网站在线观看| 成人欧美一区二区三区黑人| 国产91av在线| 久久久久女教师免费一区| 2019中文字幕全在线观看| 亚洲欧美制服丝袜| 久久中文字幕在线视频| 亚洲天堂免费在线| 亚洲风情亚aⅴ在线发布| 高跟丝袜欧美一区| 韩国精品美女www爽爽爽视频| 亚洲人成网站999久久久综合| 亚洲石原莉奈一区二区在线观看| 日韩国产在线看| www欧美日韩| 91精品中文在线| 亚洲欧美激情另类校园| 91精品国产综合久久香蕉| 欧美影院久久久| 性欧美xxxx视频在线观看| 久久久久成人精品| 亚洲欧美综合图区| 日韩中文字幕精品视频| 欧美日韩在线视频首页| 午夜精品视频网站| 中文字幕日韩综合av| www国产精品com| 精品二区三区线观看| 国产精品国产三级国产专播精品人| 久久夜色精品亚洲噜噜国产mv| 国产精品成人播放| 久久成人人人人精品欧| 国产精品69精品一区二区三区| 亚洲大胆人体av| 国产精品一香蕉国产线看观看| 国产精品亚洲精品| 久久影视电视剧凤归四时歌| 欧美久久精品一级黑人c片| 91情侣偷在线精品国产| 欧美日韩精品中文字幕| 国产午夜精品视频| 国产不卡精品视男人的天堂| 91av在线影院| 欧美国产日韩中文字幕在线| 色先锋资源久久综合5566| 热re91久久精品国99热蜜臀| 中文字幕一精品亚洲无线一区| 日韩精品视频免费专区在线播放| 神马久久桃色视频| 狠狠躁夜夜躁人人爽超碰91| 亚洲自拍欧美色图| 亚洲黄色在线看| 欧美亚洲另类激情另类| 26uuu国产精品视频| 亚洲精品视频网上网址在线观看| 久久夜色精品国产欧美乱| 一区二区三区天堂av| 欧美肥臀大乳一区二区免费视频| 欧美日韩亚洲一区二| 中文字幕视频一区二区在线有码| 久久亚洲综合国产精品99麻豆精品福利| 色老头一区二区三区在线观看| 国产91色在线|免| 2019日本中文字幕| 亚洲mm色国产网站| 国产成人精品在线| 亚洲肉体裸体xxxx137| 欧美超级乱淫片喷水| 精品视频久久久久久| 国产精品777| 一本一本久久a久久精品牛牛影视| 精品偷拍各种wc美女嘘嘘| 91在线免费视频| 国产欧美精品日韩精品| 欧美日韩成人精品| 91在线色戒在线| 91亚洲国产成人久久精品网站| 亚洲一区免费网站| 深夜福利91大全| 精品国产一区二区在线| 久久久久久香蕉网| 亚洲欧美国产视频| 91色视频在线导航| 国产精品久久久久久久7电影| 国产美女久久精品香蕉69| 欧美激情精品久久久久久免费印度| 欧美午夜片欧美片在线观看| 欧美性xxxx在线播放| 亚洲精品一区二三区不卡| 亚洲999一在线观看www| 一色桃子一区二区| 亚洲精品久久7777777| 日韩欧美国产成人| 色婷婷av一区二区三区久久| 亚洲一区www| 国产精品久久久久久久久借妻| 7777精品久久久久久| 日韩精品在线第一页| 色先锋资源久久综合5566| 国产精品女主播视频| 久久精品人人爽| 日韩中文娱乐网| 欧美日韩在线视频一区二区| 国产免费久久av| 久久成人av网站| 亚洲精品国产欧美| 日本精品久久中文字幕佐佐木| 亚洲第一天堂无码专区| 欧美国产视频日韩| 91精品久久久久久久久久另类| 精品久久久久久亚洲国产300| 久久久久久久久久久人体| 亚洲成人国产精品| 日韩美女在线观看一区| 日韩亚洲在线观看| 91国在线精品国内播放| 国产精品大片wwwwww| 欧美一级视频免费在线观看| 18一19gay欧美视频网站| 亚洲国产精品久久久久秋霞不卡| 欧美激情视频一区| 亚洲**2019国产| 91久久国产精品91久久性色| 国产精品亚洲视频在线观看| 成人在线视频网站| 精品国产乱码久久久久久天美| 久久夜色撩人精品| 欧美亚洲午夜视频在线观看| 国产美女精品视频免费观看| 亚洲一区www| 亚洲欧美中文在线视频| 久久久成人av| 91精品在线看| 亚洲精品久久久久久下一站| 久久精品国产69国产精品亚洲| 国产有码一区二区| 日韩大陆毛片av| 尤物tv国产一区| 丝袜美腿精品国产二区| 91免费人成网站在线观看18| 亚洲国产成人精品久久久国产成人一区| 成人国产在线激情| 欧美激情一区二区久久久| 九九热精品视频| 亚洲一区二区三区乱码aⅴ|