首頁 > web前端 > js教程 > JavaScript匿名函數用法分析_javascript技巧

JavaScript匿名函數用法分析_javascript技巧

WBOY
發布: 2016-05-16 16:14:15
原創
1201 人瀏覽過

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板