本文實例講述了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程序設計有所幫助。