本文實例講述了JavaScript匿名函數用法。分享給大家供大家參考。具體如下:
一、定義一個函數
在JavaScript中,可以透過「函數宣告」和「函數表達式」來定義一個函數,例如
1、透過「函數宣告」定義一個函數
function t1(){}
2、透過「函數表達式」定義一個函數
t2 = function(){}
但是兩種方式定義函數,效果是不同的
t1是函數聲明,在『詞法分析』時,AO.t1 = function(){},-------------在『詞法分析』階段就發揮作用
t2是賦值操作,在‘運行'時,AO.t2 = function(){},值是右邊的表達式返回的結果,------在‘運行'階段才發揮作用
二、匿名函數
在JavaScript中,小括號()裡的語句當做表達式來執行,在上面說到,可以使用「函數表達式」來定義一個函數,那麼,我們可以在()內定義一個函數,如
(function t3(){alert(' i am t3');})
如果函數沒有使用名字,修改如下
(function(){alert(' i am t3');})
包含在()內的語句既然是表達式,就有返回值,(function(){alert(' i am t3');})的返回值就是定義的函數,可以立即調用,如
(function(){alert(' i am t3');})()
因此,在小括號()內定義一個沒有名字的函數,該函數稱為匿名函數。這種手法,匿名函數,立即執行,不污染全局,稱為 立即執行函數表達式。
三、jquery就是一個匿名函數
jquery的程式碼就是封裝在一個匿名函數中,這是jquery最外層的程式碼:
(function(window,undefined){})(window);//立即调用
但是jquery為什麼要傳window,不傳undefined呢?
答:傳window是為了找出速度,減少查詢變數的時間。例如下面這段js程式碼
function(){ function(){ function(){ function(){ document.getElementById(); //这个document将会沿作用域层层上找,直到最外层window全局。 } } } }
jquery就是為了加快內部找出局部變數的速度,而直接把window以參數形式傳進來, 這樣window就在jquery內部AO上。
不傳undefined是為了安全,因為在低版的IE,FF中,undefined竟然可以重新賦值,如 undefined=3;
宣告局部變數undefined(名字是undefined),同時,又不傳參,值自然就是undefined
希望本文所述對大家的javascript程式設計有所幫助。