本文實例講述了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、閉包是由函數和其相關的引用環境組合而成的實體。(潛臺詞就是這個函數將和引用環境同時存在,必須有引用)
綜合來說,不管怎么定義都是在圍繞著兩個本質:函數在引用變量,這個變量將不會被銷毀。
什么叫做被引用的自由變量離開了創造它的環境?如下:
新聞熱點
疑難解答
圖片精選