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

首頁 > 開發 > JS > 正文

JavaScript解析機制與閉包原理實例詳解

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

本文實例講述了JavaScript解析機制與閉包原理。分享給大家供大家參考,具體如下:

js解析機制:

js代碼解析之前會創建一個如下的詞法環境對象(倉庫):LexicalEnvironment{ }

在掃描js代碼時會把:

1、用聲明的方式創建的函數的名字;

2、用var定義的變量的名字存到這個詞法環境中;

3、同名的時候:函數聲明會覆蓋變量,下面的函數聲明會覆蓋上面的同名函數;

4、函數的值為:對函數的一個引用; 變量的值為undefined;

5、如果用函數表達式的方式創建一個函數:

var fn = function(){ } 這樣詞法環境中存的是一個變量名fn,并賦值為undefined;

在調用函數的時候如果在函數上面調用就會出現和變量一樣的情況報錯undefined;

這也是以兩種不同方式創建函數的區別;

LexicalEnvironment(這個詞法環境===window){fn: 對函數的一個引用;b:undefined;}

用聲明的方式創建的函數:

function fn(){ };

用var定義的變量:

var b=5;

每次調用函數的時候就會創建一個新的詞法環境對象(倉庫):LexicalEnvironment{ };
在解析函數內部的變量和函數聲明的時候跟全局詞法環境相同,不過有兩點需要注意,如下:

LexicalEnvironment(這個詞法環境===fn){a:對函數的一個引用;(解析的時候函數聲明把變量覆蓋了,盡管變量已經被賦值為1)b:2;(解析的時候把變量存在了詞法環境里,同時賦值為2)}

 

function fn (a,b){  alert(a)// function a(){ }  alert(b)//2  var b= 100;  function a(){ }}fn(1,2);

調用函數并傳遞參數的時候,詞法環境里會再存變量名的同時賦值,如果是函數內部有同名的函數聲明則會把傳入的參數覆蓋;如果形參只有一個,那么另一個實參則被賦值為undefined;

閉包:

定義:(有多種定義)

1、(比較通俗的定義):函數嵌套函數,內部函數可以引用外部函數的參數和變量,這些參數和變量不會被垃圾回收機制所回收;

2、在計算機科學中,閉包是詞法閉包的簡稱,是引用了自由變量的函數,這個被引用的自由變量將和這個函數一同存在,即使已經離開了創造它的環境也不例外(意思就是不會被銷毀)。

3、閉包是由函數和其相關的引用環境組合而成的實體。(潛臺詞就是這個函數將和引用環境同時存在,必須有引用)

綜合來說,不管怎么定義都是在圍繞著兩個本質:函數在引用變量,這個變量將不會被銷毀。

什么叫做被引用的自由變量離開了創造它的環境?如下:

function fn(){  var a = 10;  var b = 20;  return function fn2(){    alert(a);  }}var result = fn();result();//10;

以上代碼就是fn2在被return出去以后,離開了fn函數這個環境,但是在外部調用依然能夠訪問到fn的變量;

這就是被引用的變量不會被銷毀;同理在自執行函數這個閉包里,雖然自執行函數在自身執行過后內部變量本該被垃圾回收機制所回收,但是由于其內部有引用它的變量的子函數,也就是說構成了閉包,它的變量依然不會被銷毀;

由此可見閉包的一個作用就是:我們能夠通過閉包的方法來在外部訪問到一個內部函數的變量;

很多人在解釋閉包的時候都會把子函數return出去以后在外部調用,其實無論在哪里調用,閉包都已經形成了,只要是函數嵌套函數,并且子函數引用了父函數的變量,(不論子函數有沒有被調用,這個用一種方法證明:在子函數內部打斷點,在f12中觀察閉包里的內容,已經出現了引用函數,這時候調用還沒有被執行)這個時候閉包已經形成了。

閉包的本質:就是形成了作用域鏈。

注意:形成閉包的條件:1、函數要嵌套;2、子函數要引用父函數的變量(如果沒有引用,則不會形成閉包,如果是引用父函數的父函數的變量也會形成閉包);

父函數每調用一次,就會形成一個新的閉包(函數每調用一次,就 會復制一份),也就是說形成一個新的詞法作用域,重新引用父函數的變量;

以下代碼說明:

function fn() {  var num = 1;  return function() {    num++;    alert(num);  }}var result1 = fn();result1();//2;result1();//3;var result2 = fn();result2();//2;result2();//3;

在fn被調用兩次時,都形成了新的閉包,有各自新的詞法作用域,所以result2的輸出結果不受result1的影響;

函數每調用一次,都會復制一份新的,可以說明for循環里i的問題;

for (var i = 0; i < 5; i++) {  (function(index){    oDiv.onclick = function() {      alert(index)    }  })(i)}

自執行函數每調用一次都會復制一份新的,傳進的i值也在變化,由于在函數靜態作用域里,在預解析階段已經確定了變量的作用域,所以子函數引用的父函數變量index只能是每次復制的那個父函數變量,所以就實現了我們想要取不同的i值的目的;

閉包的用途:

1、匿名自執行函數

不污染全局變量,(否則被聲明為全局變量的話別的函數可能誤用這些變量;造成全局對象過于龐大,影響訪問速度(因為變量的取值是需要從原型鏈上遍歷的)。提高效率;

2、結果緩存:

我們開發中會碰到很多情況,設想我們有一個處理過程很耗時的函數對象,每次調用都會花費很長時間利用閉包,它不會釋放外部的引用,從而函數內部的值可以得以保留。,這樣我們在第二次調用的時候,就會從緩存中讀取到該資源。

3、實現封裝;

4、實現類和繼承(構造函數);

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


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产欧美精品日韩精品| 97精品视频在线| 国产一区二区三区在线视频| 久久久久久久久久久成人| 久久久久久久久久久av| 国产亚洲人成网站在线观看| 久久大大胆人体| 精品国产一区二区三区久久久| 亚洲级视频在线观看免费1级| 欧美一级高清免费播放| 精品久久久视频| 久久精品亚洲精品| …久久精品99久久香蕉国产| 亚洲综合在线播放| 久久中文久久字幕| 浅井舞香一区二区| 亚洲三级免费看| 欧美亚洲国产日本| 国产一区二区黑人欧美xxxx| 国产成人在线亚洲欧美| 国产亚洲aⅴaaaaaa毛片| 国产成人一区二区三区| 亚洲第一页中文字幕| 国产成人综合亚洲| 日本午夜人人精品| 青青久久av北条麻妃海外网| 国产福利精品av综合导导航| 欧美另类交人妖| 国产精品久久久久久婷婷天堂| 欧美极品欧美精品欧美视频| 久久精品色欧美aⅴ一区二区| 国产日韩精品综合网站| 亚洲人成电影在线观看天堂色| 91麻豆国产语对白在线观看| 91在线色戒在线| 欧美高清激情视频| 国产精品女视频| 欧美精品久久久久久久久久| 亚洲女人被黑人巨大进入| 亚洲精品欧美一区二区三区| 精品国产精品三级精品av网址| 欧美成人午夜剧场免费观看| 日韩免费视频在线观看| 福利微拍一区二区| 日韩成人在线免费观看| 2019中文在线观看| 日韩毛片在线看| 日韩美女免费观看| 亚洲人成网站999久久久综合| 91久久在线视频| 欧美自拍视频在线| 久久精品成人一区二区三区| 亚洲第一中文字幕在线观看| 国产男女猛烈无遮挡91| 一本色道久久综合狠狠躁篇怎么玩| 欧美成人免费一级人片100| 亚洲免费小视频| 97激碰免费视频| 亚洲精品电影网| 北条麻妃99精品青青久久| 九九热r在线视频精品| 欧美视频一区二区三区…| 精品视频在线观看日韩| 成人久久一区二区三区| 国产精品国产三级国产aⅴ9色| 亚洲自拍另类欧美丝袜| 一区二区在线视频播放| 91欧美精品午夜性色福利在线| 欧美孕妇孕交黑巨大网站| 亚洲精品ady| 亚洲精品视频在线播放| 91国内免费在线视频| 国内精品久久久久久中文字幕| 欧美大奶子在线| 欧美在线视频播放| 国产97色在线| 555www成人网| 8050国产精品久久久久久| 黄色一区二区在线| 亚洲精品中文字幕av| 欧美激情欧美激情在线五月| 国产91精品久久久久| 最近2019年好看中文字幕视频| 亚洲精品在线观看www| 国产精品专区一| 久久99精品久久久久久噜噜| 欧美大片欧美激情性色a∨久久| 亚洲精品中文字幕女同| 色妞久久福利网| 日韩精品中文字幕在线播放| 欧美日韩在线视频首页| 九九久久综合网站| 国产精品第1页| 黑人狂躁日本妞一区二区三区| 精品国产成人在线| 亚洲精品720p| 亚洲欧美国产日韩中文字幕| 在线看福利67194| 国产精品一区二区久久| 国产精品视频色| 91欧美精品午夜性色福利在线| 国产精品久久久久久久久久小说| 国产欧美日韩精品丝袜高跟鞋| 久久久久久成人精品| 国产成人中文字幕| 成人国产在线视频| 91高清视频免费观看| 欧美体内谢she精2性欧美| 亚洲丝袜一区在线| 国产一区二区三区在线看| 91牛牛免费视频| 欧美另类精品xxxx孕妇| 在线日韩欧美视频| 精品久久久久久久久久久久久久| 国产高清视频一区三区| 亚洲国产高清自拍| 欧美在线性视频| 日韩精品中文字| 欧美精品videossex88| 欧美电影免费观看高清完整| 日韩电影免费观看中文字幕| 5278欧美一区二区三区| 2019中文字幕在线| 国内揄拍国内精品少妇国语| 在线精品播放av| 97色在线观看免费视频| 欧美插天视频在线播放| 国产精品久久久久久久久久| 久久久免费精品| 国产成人久久精品| 亚洲第一页自拍| 国产精品ⅴa在线观看h| 欧美黑人又粗大| 亚洲人成网站色ww在线| 欧美与欧洲交xxxx免费观看| 精品久久久av| 九九精品视频在线| 色午夜这里只有精品| 亚洲2020天天堂在线观看| 91精品国产乱码久久久久久蜜臀| 国产伦精品一区二区三区精品视频| 国产成+人+综合+亚洲欧洲| 久久乐国产精品| 亚洲一区美女视频在线观看免费| 姬川优奈aav一区二区| 欧美成人激情视频| 久久久人成影片一区二区三区| 清纯唯美亚洲激情| 国模叶桐国产精品一区| 欧美洲成人男女午夜视频| 亚洲一区二区三区乱码aⅴ| 欧美日产国产成人免费图片| 欧美激情久久久| 亚洲自拍偷拍网址| 国产成人免费91av在线| 亚洲香蕉伊综合在人在线视看| 国产91ⅴ在线精品免费观看| 毛片精品免费在线观看| 国产精品福利观看| 亚洲成人激情小说| 国模精品视频一区二区三区| 亚洲aⅴ男人的天堂在线观看| 2018中文字幕一区二区三区| 欧美成人精品在线播放|