欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript 用函數(shù)語句和表達(dá)式定義函數(shù)的區(qū)別詳解

 更新時(shí)間:2014年01月06日 08:47:55   作者:  
本篇文章主要介紹了javascript 用函數(shù)語句和表達(dá)式定義函數(shù)的區(qū)別。需要的朋友可以過來參考下,希望對(duì)大家有所幫助

使用javascript多年,寫過無數(shù)函數(shù),今天卻才真正弄明白兩種函數(shù)定義的區(qū)別,真是悲劇,寫下這個(gè)隨筆, 以時(shí)刻提醒自己要打好基礎(chǔ) , 一大把年紀(jì)了, 不能繼續(xù)懵懵懂懂了。

通常我們會(huì)看到以下兩種定義函數(shù)的方式:

復(fù)制代碼 代碼如下:

// 函數(shù)語句
function fn(str)
{
  console.log(str);
};

// 表達(dá)式定義
var fnx=function(str)
{
  console.log(str+ ' from fnx');
};


以前都是憑借自己手指的感覺隨心所欲使用兩者 -_- || ,今天看了js基礎(chǔ), 總算是解決了心中對(duì)他們的困惑:

兩種方式都創(chuàng)建了新的函數(shù)對(duì)象, 但函數(shù)聲明語句的函數(shù)名是一個(gè)變量名, 變量指向函數(shù)對(duì)象, 和通過var聲明變量一樣,函數(shù)定義語句中的函數(shù)被顯示地提前到了腳本或函數(shù)的頂部, 因此它們?cè)谡麄€(gè)腳本和函數(shù)內(nèi)都是可見的,但是使用var 表達(dá)式定義函數(shù), 只有變量聲明提前了,變量初始化代碼仍然在原來的位置, 用函數(shù)語句創(chuàng)建的函數(shù), 函數(shù)名稱和函數(shù)體均被提前,所以我們可以在聲明它之前就使用它。

代碼例子如下:

復(fù)制代碼 代碼如下:

   console.log(typeof(fn)); // function
    fn('abc'); // abc


    console.log(typeof(fnx)); // undefined

    if(fnx)
        fnx('abc');  // will not execute
    else
        console.log('fnx is undefined'); // fnx is undefined

    // 函數(shù)語句
    function fn(str)
    {
        console.log(str);
    };

    // 表達(dá)式定義
    var fnx=function(str)
    {
        console.log(str+ ' from fnx');
    };


代碼很簡單, 希望和我之前一樣沒有弄明白兩者區(qū)別的同學(xué)能有所收獲 。

相關(guān)文章

最新評(píng)論