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

淺析javascript中函數(shù)聲明和函數(shù)表達(dá)式的區(qū)別

 更新時(shí)間:2015年02月15日 09:37:34   投稿:hebedich  
這篇文章主要介紹了淺析javascript中函數(shù)聲明和函數(shù)表達(dá)式的區(qū)別,需要的朋友可以參考下

javascript中聲明函數(shù)的方法有兩種:函數(shù)聲明式和函數(shù)表達(dá)式.

區(qū)別如下:

1).以函數(shù)聲明的方法定義的函數(shù),函數(shù)名是必須的,而函數(shù)表達(dá)式的函數(shù)名是可選的.

2).以函數(shù)聲明的方法定義的函數(shù),函數(shù)可以在函數(shù)聲明之前調(diào)用,而函數(shù)表達(dá)式的函數(shù)只能在聲明之后調(diào)用.

3).以函數(shù)聲明的方法定義的函數(shù)并不是真正的聲明,它們僅僅可以出現(xiàn)在全局中,或者嵌套在其他的函數(shù)中,但是它們不能出現(xiàn)在循環(huán),條件或者try/catch/finally中,而

    函數(shù)表達(dá)式可以在任何地方聲明.

下面分別用兩種方法定義函數(shù):

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

 //函數(shù)聲明式
 function greeting(){
       console.log("hello world"); 
 }
 //函數(shù)表達(dá)式
 var greeting = function(){
     console.log("hello world");
 }

下面一個(gè)有趣的javascript:

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

 function f() { console.log('I am outside!'); }
 (function () {
   if(false) {
     // 重復(fù)聲明一次函數(shù)f
     function f() { console.log('I am inside!'); }
   }
   f();
 }());

會(huì)輸出什么呢?第一反應(yīng)應(yīng)該是"I am outside"吧.  結(jié)果在chrome中輸出"I am inside",IE11直接報(bào)錯(cuò),firefox低一點(diǎn)的版本輸出"I am outside"...

chrome輸出的結(jié)果很明確的反應(yīng)了用函數(shù)聲明式聲明的函數(shù)的特點(diǎn)--函數(shù)在聲明之前就可以調(diào)用.

IE報(bào)錯(cuò)顯示缺少對(duì)象,因?yàn)楹瘮?shù)聲明在了條件里,違背了函數(shù)聲明式的原則.

函數(shù)表達(dá)式的作用域:

如果函數(shù)表達(dá)式聲明的函數(shù)有函數(shù)名,那么這個(gè)函數(shù)名就相當(dāng)于這個(gè)函數(shù)的一個(gè)局部變量,只能在函數(shù)內(nèi)部調(diào)用,舉個(gè)栗子:

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

 var f = function fact(x) {
                 if (x <= 1)
                     return 1;
                 else
                     return x*fact(x-1);
                 };
                 alert(fact());   // Uncaught ReferenceError: fact is not defined

fact()在函數(shù)內(nèi)部可以調(diào)用,在函數(shù)外部調(diào)用就會(huì)報(bào)錯(cuò):fact未定義

以上就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。

相關(guān)文章

  • JS實(shí)現(xiàn)圖片元素轉(zhuǎn)BASE64編碼的簡(jiǎn)單示例

    JS實(shí)現(xiàn)圖片元素轉(zhuǎn)BASE64編碼的簡(jiǎn)單示例

    在Web開(kāi)發(fā)中,我們經(jīng)常需要將圖片轉(zhuǎn)換為Base64格式,以便在不依賴外部資源的情況下直接在HTML中使用,在這篇文章中,我將向您展示如何使用JavaScript將圖片元素轉(zhuǎn)BASE64編碼,需要的朋友可以參考下
    2023-12-12
  • js實(shí)現(xiàn)篩選功能

    js實(shí)現(xiàn)篩選功能

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)篩選功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • js 獲取圖像縮放后的實(shí)際寬高,位置等信息

    js 獲取圖像縮放后的實(shí)際寬高,位置等信息

    本文主要介紹了js獲取圖像縮放后的實(shí)際寬高,位置等信息的方法,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧
    2017-03-03
  • AJAX請(qǐng)求與跨域問(wèn)題解決方法詳解

    AJAX請(qǐng)求與跨域問(wèn)題解決方法詳解

    學(xué)習(xí)ajax必須得掌握的就是跨域請(qǐng)求,實(shí)際上在不同源的地址上發(fā)送請(qǐng)求就是跨域請(qǐng)求,本文主要給大家介紹了關(guān)于AJAX請(qǐng)求以及解決跨域問(wèn)題的相關(guān)資料,需要的朋友可以參考下
    2022-11-11
  • JavaScript Eval 函數(shù)使用

    JavaScript Eval 函數(shù)使用

    JavaScript Eval 函數(shù)使用,需要的朋友可以參考下。
    2010-03-03
  • 詳解js中Array的方法及技巧

    詳解js中Array的方法及技巧

    這篇文章我們給大家總結(jié)了關(guān)于js中Array的方法及技巧,有需要的朋友們可以學(xué)習(xí)參考下。
    2018-09-09
  • JS+DIV實(shí)現(xiàn)拖動(dòng)效果

    JS+DIV實(shí)現(xiàn)拖動(dòng)效果

    這篇文章主要為大家詳細(xì)介紹了JS+DIV實(shí)現(xiàn)拖動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • D3.js實(shí)現(xiàn)樹(shù)形圖的繪制教程詳解

    D3.js實(shí)現(xiàn)樹(shù)形圖的繪制教程詳解

    樹(shù)形圖(Tree?Diagram)是用來(lái)表示一個(gè)概率空間。樹(shù)形圖可以表示獨(dú)立事件(例如多次擲硬幣)和條件概率(例如不放回的抽卡)。本文將利用D3.js實(shí)現(xiàn)樹(shù)形圖的繪制,需要的可以參考一下
    2022-11-11
  • 微信小程序?qū)崿F(xiàn)手風(fēng)琴折疊面板

    微信小程序?qū)崿F(xiàn)手風(fēng)琴折疊面板

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)手風(fēng)琴折疊面板,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • JavaScript實(shí)現(xiàn)時(shí)鐘滴答聲效果

    JavaScript實(shí)現(xiàn)時(shí)鐘滴答聲效果

    本文給大家分享一段js實(shí)例代碼實(shí)現(xiàn)時(shí)鐘滴答聲效果,效果逼真,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-01-01

最新評(píng)論