国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

JS閉包用法實例分析

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

本文實例講述了JS閉包用法。分享給大家供大家參考,具體如下:

<!DOCTYPE html><html>  <head>    <meta charset="UTF-8">    <title></title>  </head>  <body>    <script type="text/javascript">//      第一,函數作為返回值      function fn(){        var max = 10;        return function bar(x){          if(x > max) {            console.log(x);          }        };      }      var f1 = fn();      f1(15);    </script>    <script type="text/javascript">//      第二,函數作為參數被傳遞      var max = 10;      fn = function(x){        if(x > max){          console.log(x);//15        }      };      (function(f){        var max = 100;        f(15);      })(fn);    </script>    <script>      function fn(){        var max = 10;        return function bar(x){          if(if > max){            console.log(x);          }        };      }      var f1 = fn();        max = 100;      f1(15);    </script>  </body></html>

第一步,代碼執行前生成全局上下文環境,并在執行時對其中的變量進行賦值。此時全局上下文環境是活動狀態。

全局上下文環境:max是undefined

第二步,執行var f1 = fn();代碼時,調用fn(),產生fn()執行上下文環境,壓棧,并設置為活動狀態。

fn()上下文環境:max是10

第三步,執行完var f1 = fn();,fn()調用完成。按理說應該銷毀掉fn()的執行上下文環境,但是這里不能這么做。

注意,重點來了:因為執行fn()時,返回的是一個函數。函數的特別之處在于可以創建一個獨立的作用域。

而正巧合的是,返回的這個函數體中,還有一個自由變量max要引用fn作用域下的fn()上下文環境中的max。

因此,這個max不能被銷毀,銷毀了之后bar函數中的max就找不到值了。因此,這里的fn()上下文環境不能被銷毀,還依然存在與執行上下文棧中。

執行到max = 100;時,全局上下文環境將變為活動狀態,但是fn()上下文環境依然會在執行上下文棧中。

另外,執行完max = 100;,全局上下文環境中的max被賦值為100。

全局上下文環境:max是100 fn()上下文環境:max是10

第四步,執行到f1(15);,執行f1(15),即執行bar(15),創建bar(15)上下文環境,并將其設置為活動狀態。

執行bar(15)時,max是自由變量,需要向創建bar函數的作用域中查找,找到了max的值為10。

這里的重點就在于,創建bar函數是在執行fn()時創建的。fn()早就執行結束了,但是fn()執行上下文環境還存在與棧中,因此bar(15)時,max可以查找到。如果fn()上下文環境銷毀了,那么max就找不到了。

使用閉包會增加內容開銷,現在很明顯了吧!

第五步,執行完f1(15);就是上下文環境的銷毀過程,這里就不再贅述了。

閉包和作用域、上下文環境有著密不可分的關系,真的是“想說愛你不容易”!

另外,閉包在jQuery中的應用非常多,無論你是想了解一個經典的框架/類庫,還是想自己開發一個插件或者類庫,像閉包、原型這些基本的理論,是一定要知道的。否則,到時候出了BUG你都不知道為什么,因為這些BUG可能完全在你的知識范圍之外。

希望本文所述對大家Javascript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 和平区| 阳新县| 黑河市| 鄂伦春自治旗| 西青区| 宣武区| 大姚县| 集贤县| 沙坪坝区| 石家庄市| 雷州市| 当涂县| 抚远县| 松江区| 嘉义县| 大英县| 磐安县| 简阳市| 凌海市| 碌曲县| 开原市| 宝应县| 漳浦县| 安庆市| 舒兰市| 厦门市| 天津市| 临沧市| 定日县| 斗六市| 平乐县| 龙南县| 日土县| 阜宁县| 德格县| 易门县| 石泉县| 洱源县| 山东省| 山东省| 满洲里市|