<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    瘋狂

    STANDING ON THE SHOULDERS OF GIANTS
    posts - 481, comments - 486, trackbacks - 0, articles - 1
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    函數聲明 VS 函數表達式(轉)

    Posted on 2013-12-28 15:16 瘋狂 閱讀(1577) 評論(0)  編輯  收藏

    轉自:http://www.libuchao.com/2012/06/25/function-declaration-vs-function-expression
    JavaScript 中需要創建函數的話,有兩種方法:函數聲明、函數表達式,各自寫法如下:

    // 方法一:函數聲明
    function foo() {}
    
    // 方法二:函數表達式
    var foo = function () {};
    

    另外還有一種自執行函數表達式,主要用于創建一個新的作用域,在此作用域內聲明的變量不會和其它作用域內的變量沖突或混淆,大多是以匿名函數方式存在,且立即自動執行:

    (function () {
        // var x = ...
    })();
    

    此種自執行函數表達式歸類于以上兩種方法的第二種,也算是函數表達式。

    方法一和方法二都創建了一個函數,且命名為 foo,但是二者還是有區別的。JavaScript 解釋器中存在一種變量聲明被提升(hoisting)的機制,也就是說變量(函數)的聲明會被提升到作用域的最前面,即使寫代碼的時候是寫在最后面,也還是會被提升至最前面。

    例如以下代碼段:

    alert(foo); // function foo() {}
    alert(bar); // undefined
    function foo() {}
    var bar = function bar_fn() {};
    alert(foo); // function foo() {}
    alert(bar); // function bar_fn() {}
    

    輸出結果分別是function foo() {}undefinedfunction foo() {}function bar_fn() {}

    可以看到 foo 的聲明是寫在 alert 之后,仍然可以被正確調用,因為 JavaScript 解釋器會將其提升到 alert 前面,而以函數表達式創建的函數 bar 則不享受此待遇。

    那么bar 究竟有沒有被提升呢,其實用 var 聲明的變量都會被提升,只不過是被先賦值為 undefined 罷了,所以第二個 alert 彈出了 undefined

    所以,JavaScript 引擎執行以上代碼的順序可能是這樣的:

    1. 創建變量 foobar,并將它們都賦值為 undefined
    2. 創建函數 foo 的函數體,并將其賦值給變量 foo
    3. 執行前面的兩個 alert。
    4. 創建函數 bar_fn,并將其賦值給 bar
    5. 執行后面的兩個 alert。

    注:

    嚴格地說,再 JavaScript 中創建函數的話,還有另外一種方法,稱為“函數構造法”:

    var foo = Function('alert("hi!");');
    var foo = new Function('alert("hi!");'); // 等同于上面一行
    

    此方法以一個字符串作為參數形成函數體。但是用這種方法,執行效率方面會打折扣,且似乎無法傳遞參數,所以少用為妙。


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 亚洲av无码一区二区三区天堂| 亚洲色大成网站www| 亚洲精品高清国产一久久| 亚洲国产一区二区a毛片| 亚洲第一页在线播放| 亚洲字幕AV一区二区三区四区| 激情综合亚洲色婷婷五月| 亚洲youwu永久无码精品| 久久最新免费视频| 久视频精品免费观看99| 亚洲成?v人片天堂网无码| 亚洲av无码片在线播放| 亚洲精华液一二三产区| 中文在线观看国语高清免费| 在线精品免费视频| 久久久久久a亚洲欧洲aⅴ| 亚洲色精品三区二区一区| 日本在线免费观看| 久久国产成人亚洲精品影院| 亚洲日本在线播放| 不卡视频免费在线观看| 成人免费毛片观看| 亚洲成a人片在线观看中文app| 一级毛片免费在线观看网站| 青青久在线视频免费观看| 亚洲av无码一区二区乱子伦as| 色婷婷精品免费视频| 成人免费无码大片A毛片抽搐| 亚洲精品国产福利片| 叮咚影视在线观看免费完整版| 日韩亚洲精品福利| 亚洲AV无码AV日韩AV网站| 毛片免费vip会员在线看| 亚洲天堂一区在线| 青娱乐免费在线视频| 亚洲人JIZZ日本人| 久久综合九色综合97免费下载| 亚洲色欲色欲www在线丝| 两性色午夜免费视频| 国产亚洲美女精品久久久久狼 | 亚洲一区二区三区丝袜|