亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js閉包實例匯總

 更新時間:2014年11月09日 09:29:21   投稿:hebedich  
本文是通過實例來幫助大家深刻理解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的話,一樣會報沒定義的錯誤

有時,需要得到函數內部的的局部變量,就需要變通的方法實現(xiàn)利用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的區(qū)別

復制代碼 代碼如下:

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

閉包

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

復制代碼 代碼如下:

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

</script>

把匿名函數的執(zhí)行結果(即對里面子函數的聲明賦給全局變量cut),i就保存在內存里了
執(zhí)行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循環(huán)停止
發(fā)現(xiàn)均彈出5,明顯不符合我們的要求

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

復制代碼 代碼如下:

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);
}

但是我們發(fā)現(xiàn) 返回的數組里的元素是函數執(zhí)行的結果,但我們想要的是函數有得升級我們的代碼

解決方案2
閉包實現(xiàn)

復制代碼 代碼如下:

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); 

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

相關文章

  • 探尋Javascript執(zhí)行效率問題

    探尋Javascript執(zhí)行效率問題

    作為開發(fā)人員,Web頁面加載或刷新的速度對其網站至關重要。開發(fā)人員在各種瀏覽器中調試JavaScript的方法要少得多。比如,在Mozilla Firefox中,可以使用Firebug調試JavaScript,但仍然不能調整很多性能問題,如瀏覽器呈現(xiàn)消耗時間。
    2014-11-11
  • 詳解JavaScript的策略模式編程

    詳解JavaScript的策略模式編程

    這篇文章主要介紹了詳解JavaScript的策略模式編程,包括函數和類作為策略的情況以及多環(huán)境下的策略模式,需要的朋友可以參考下
    2015-06-06
  • 原生javascript 學習之js變量全面了解

    原生javascript 學習之js變量全面了解

    下面小編就為大家?guī)硪黄鷍avascript 學習之js變量全面了解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-07-07
  • js腳本學習 比較實用的基礎

    js腳本學習 比較實用的基礎

    js腳本學習 比較實用的基礎...
    2006-09-09
  • 學習js所必須要知道的一些

    學習js所必須要知道的一些

    學習js所必須要知道的一些...
    2007-03-03
  • 前端?el-table?本地搜索的實現(xiàn)代碼

    前端?el-table?本地搜索的實現(xiàn)代碼

    這篇文章主要介紹了前端?el-table?本地搜索的實現(xiàn)代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • javascript中new關鍵字詳解

    javascript中new關鍵字詳解

    本文給大家詳細介紹了下javascript中new關鍵字的使用方法,以及javascript 使用new關鍵字的區(qū)別,有需要的小伙伴可以參考下。
    2015-12-12
  • 淺談JavaScript中的Math.atan()方法的使用

    淺談JavaScript中的Math.atan()方法的使用

    這篇文章主要介紹了JavaScript中的Math.atan()方法的使用,是JS入門學習中的基礎知識,需要的朋友可以參考下
    2015-06-06
  • js中的前綁定和后綁定詳解

    js中的前綁定和后綁定詳解

    這篇文章詳細介紹了js中的前綁定和后綁定,有需要的朋友可以參考一下
    2013-08-08
  • 淺談javascript中createElement事件

    淺談javascript中createElement事件

    本文通過示例向大家簡單介紹了javascript中的createElement事件,需要的朋友可以參考下
    2014-12-12

最新評論