匿名函數
函數是JavaScript中最靈活的一種對象,這裡只是講解其匿名函數的用途。
匿名函數:就是沒有函數名稱的函數。
函數的定義,先簡單介紹一下函數的定義,大致可分為三種方式
第一種:這也是最常規的一種
function double(x){ return 2 * x; }
第二種:這個方法使用了Function建構函數,把參數列表和函數體都當作字串,很不方便,不建議使用。
var double = new Function('x', 'return 2 * x;');
第三種:
var double = function(x) { return 2* x; }
注意「=」右邊的函數就是一個匿名函數,創造完畢函數後,又將該函數賦給了變數square。
JavaScript中是沒有區塊級作用域概念的。也就是說,在區塊級語句中定義的變量,實際上是在包含函數中(外部函數)而非語句中創建的。
function outputNumber(count){ for(var i=0;i<1000;i++){ alert(i); } alert(i); //count }
函數在java、C#等語言中,變數i只會在for迴圈語句中有定義,循環結束,i也就被銷毀了。但在JavaScript中,變數i是定義在outputNumber()活動物件中的,因此在它定義開始,就可以在函數內部存取它。即使重新聲明同一個變量,也不會改變它的值。
function outputNumber(count){ for(var i=0;i<1000;i++){ alert(i); } var i; //重新声明变量 alert(i); //count }
匿名函數可以用來模仿區塊級作用域並避免這個問題,用作區塊級作用域(也稱私有作用域)的匿名函數的語法如下:
(function(){ //这是块级作用域 })()
以上程式碼定義變呼叫了一個匿名函數,將函數宣告包含在一個小括號裡面,表示它是個函數表達式。緊接在後的另一對小括號會立即呼叫這個函數。
無論什麼時候,只要臨時需要一些變量,就可以用私人作用域,例如:
function outputNumber(count){ (function(){ for(var i=0;i<1000;i++){ alert(i); })(); alert(i); //导致一个错误 }
這樣,我們在for迴圈外部插入了一個私有作用域。在匿名函數中定義的任何變量,都會在執行結束時被銷毀。
這種技術經常在全域作用域中被用在函數外部,從而限制在全域作用域中添加過多的變數和函數。
一般來說,我們應該盡量減少在全域作用域中加入變數和函數。
這種做法可以減少閉包佔用記憶體的問題,因為沒有指向匿名函數的引用,只要函數執行完畢,就可以立即銷毀其作用域鏈。