国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

細說 Javascript 函數(shù)篇(一) : 函數(shù)聲明和函數(shù)表達式

hizengzeng / 3365人閱讀

摘要:函數(shù)表達式對于函數(shù)聲明,函數(shù)的名稱是必須的,而對于函數(shù)表達式而言則是可選的,因此,就出現(xiàn)了匿名函數(shù)表達式和命名函數(shù)表達式。這是因為對命名函數(shù)處理的機制,函數(shù)的名稱永遠在函數(shù)內部的作用域中有效。

functionJavascript 中的第一類對象,這就意味著函數(shù)可以像其他值一樣被傳遞。一個最常見的用法就是將一個匿名函數(shù)作為回調函數(shù)傳遞到另外一個異步函數(shù)中。

函數(shù)聲明
function foo() {}

函數(shù) foo 將會在整個程序執(zhí)行前被 hoist (提升),因此它在定義 foo 函數(shù)的整個 scope (作用域)中都是可用的。即使在函數(shù)定義之前調用它也沒問題。

foo(); // Works because foo was created before this code runs
function foo() {}
  

因為我打算專門寫篇介紹作用域的博文,所以這里就不詳述了。如果對 scopehoist 有疑惑,可用閱讀 @nightire 凡哥的博文 - 《理解 JavaScript(二)》,里面詳細介紹了 scopehoist 的含義和用法。

函數(shù)表達式

對于函數(shù)聲明,函數(shù)的名稱是必須的,而對于函數(shù)表達式而言則是可選的,因此,就出現(xiàn)了匿名函數(shù)表達式和命名函數(shù)表達式。如下:

函數(shù)聲明: function functionName (){ }

函數(shù)聲明: function functionName[可選](){ }

那么我就知道,如果沒有函數(shù)名的話,一定就是函數(shù)表達式,但是對于有函數(shù)名的情況該如何判斷呢?
Javascript 規(guī)定如果整個函數(shù)體是作為表達式的一部分時,那么它就是函數(shù)表達式,否則即是函數(shù)聲明。以下為表達式:

var fuc = foo(){}

我們再舉幾個極端的表達式例子:

!function foo(){}
true && function foo(){}

以上的語句這里只是為了區(qū)分函數(shù)表達式,一般不會這樣寫。那么用一個對比的例子來看看效果:

foo1();//foo1 is not defined 
foo2();//works because foo2 was created before this code runs
!function foo1() {
    alert("foo1 works");
};
function foo2() {
    alert("foo2 works");
};
匿名函數(shù)表達式
var foo = function() {};

上面的例子將一個匿名函數(shù)賦值給了變量 foo。

foo; // "undefined"
foo(); // this raises a TypeError
var foo = function() {};

由于 var 是一個聲明所以這里對變量 foo 進行 hoist (提升),因此當程序執(zhí)行時,變量 foo 是可調用的。
但是由于賦值語句只有在運行時才生效,所以變量 foo 的值為 undefined

命名函數(shù)表達式

另一個要講到的就是命名函數(shù)的賦值。

var foo = function bar() {
    bar(); // Works
};
bar(); // ReferenceError

在這里,命名函數(shù) bar 賦值給了變量 foo,所以在函數(shù)聲明外是不可見的,但在 bar 函數(shù)內部仍然可以調用。這是因為 Javascript 對命名函數(shù)處理的機制,函數(shù)的名稱永遠在函數(shù)內部的作用域中有效。

參考

http://bonsaiden.github.io/JavaScript-Garden/#function.general

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/87522.html

相關文章

  • 細說 Javascript 函數(shù)(六) : ?作用域與命名空間

    在之前的介紹中,我們已經知道 Javascript 沒有塊級作用,只有函數(shù)級作用域。 function test() { // a scope for(var i = 0; i < 10; i++) { // not a scope // count } console.log(i); // 10 } Javascript 中也沒有顯示的命名空間,這就...

    VishKozus 評論0 收藏0
  • 細說 Javascript 函數(shù)(五) : ?構造函數(shù)

    Javascript 中的構造函數(shù)與其他語言相比也是不同的。任何通過關鍵字 new 調用的函數(shù)都可以當做構造函數(shù)。 在構造函數(shù)體內,this 指向新創(chuàng)建的對象。如果構造函數(shù)體內沒有顯示的 return 表達式,那么我們就默認返回 this,也就是新建的對象。 function Foo() { this.bla = 1; } Foo.prototype.test = function()...

    sPeng 評論0 收藏0
  • 細說 Javascript 函數(shù)(四) : ?arguments 對象

    因為最近有博友反饋我的博文是直接翻譯的參考鏈接內的內容,所以我在這里要說明一下,以免引起不必要的誤會。 首先,我很喜歡 segmentfault 的交流和學習的氛圍,所以我很愿意在這里跟各位 SFer 交流學習心得,相互學習,共同進步。 第二,我做技術方面的工作不久,所以學習經歷也不是很長,但是我發(fā)現(xiàn)寫博客,總結自己的學習心得是個很好的學習習慣,至少對于我個人而言,我于此收益頗豐,所以我決定堅持一...

    aristark 評論0 收藏0
  • 細說 Javascript 函數(shù)(二) : this 的工作機制

    摘要:與其他編程語言相比,對的使用是一套完全不同的機制。在五種情況下的值是各有不同的。調用一個函數(shù)時在這里,同樣指向全局對象。此時在函數(shù)內,指向新建的對象。盡管,晚綁定初看上去是個不好的決定,但實際上這是原型式繼承工作的基礎。 與其他編程語言相比,Javascript 對 this 的使用是一套完全不同的機制。this 在五種情況下的值是各有不同的。 全局作用域下 this; 當在全...

    ZoomQuiet 評論0 收藏0
  • 細說 Javascript 拾遺(二) : undefined null

    摘要:有兩個可以表示空的值,分別是和,比較有作用的是前者。訪問聲明但未初始化的變量。有返回值時函數(shù)的表達式沒有顯式的返回任何內容。然而,為了比較其他變量和值,我們需要提前取得的值。因此,從標準實行后,全局變量已經是不再可寫。 Javascript 有兩個可以表示空的值,分別是 undefined 和 null,比較有作用的是前者。 undefined undefined 是一種值為 un...

    My_Oh_My 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<