精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JS 中的函數表達式和函數聲明你混淆了嗎?

開發 前端
在本文中,我們來看一下,如何使用function關鍵字來定義函數聲明和函數表達式,以及這兩種函數之間的區別又是什么。

[[407614]]

在 JavaScript 中,function關鍵字可以完成一個簡單的工作:創建一個函數。但是,使用關鍵字定義函數的方式可以創建具有不同屬性的函數。

在本文中,我們來看一下,如何使用function關鍵字來定義函數聲明和函數表達式,以及這兩種函數之間的區別又是什么。

1.函數表達式vs函數聲明

函數聲明和函數表達式是使用 function 關鍵字創建函數的2種方法。

舉個例子來說明差異,我們創建兩個版本的 sums 函數:

  1. function sumA(a, b) { 
  2.   return a + b; 
  3.  
  4. (function sumB(a, b) { 
  5.   return a + b; 
  6. }); 
  7.  
  8. sumA(1, 2); // ??? 
  9. sumB(1, 2); // ??? 

動手試試:https://jsfiddle.net/dmitri_pavlutin/8b46yokr/2/

一般情況,像往常一樣定義函數(sumA函數)。在另一種情況下,函數被放置在一對括號中(sumB函數)。

如果調用 sumA(1,2) 和 sumB(1,2) 會發生什么?

如預期的那樣,sumA(1, 2) 返回 3。但是,調用sumB(1, 2)會引發異常:Uncaught ReferenceError: sumB is not defined。

其原因是sumA是使用函數聲明創建的,該函數聲明在當前作用域中創建一個函數變量(具有與函數名稱相同的名稱)。但是sumB是使用函數表達式創建的(將其包裝在括號中),該函數表達式不會在當前作用域內創建函數變量。

如果你想訪問使用函數表達式創建的函數,那么將函數對象保存到一個變量中:

  1. // Works! 
  2. const sum = (function sumB(a, b) { 
  3.   return a + b; 
  4. }); 
  5.  
  6. sum(1, 2); // => 3 
  1. 如果語句以`function`關鍵字開頭,則為函數聲明,否則為函數表達式。 
  1. // 函數聲明:以`function`關鍵字開頭 
  2. function sumA(a, b) { 
  3.   return a + b; 
  4.  
  5. // 函數表達式:不以`function`關鍵字開頭 
  6. const mySum = (function sumB(a, b) { 
  7.   return a + b; 
  8. }); 
  9.  
  10. // 函數表達式:不以`function`關鍵字開頭 
  11. [1, 2, 3].reduce(function sum3(acc, number) {  
  12.   return acc + number  
  13. }); 

從更高的角度來看,函數聲明對于創建獨立函數很有用,但是函數表達式可以用作回調。

現在,我們更深入地研究函數聲明和函數表達式的行為。

2.函數聲明

在前面的示例中已經看到的,sumA是一個函數聲明:

  1. // Function declaration 
  2. function sumA(a, b) { 
  3.   return a + b; 
  4.  
  5. sumA(4, 5); // => 9 

當一個語句包含function關鍵字,后跟函數名稱,一對帶參數的括號(param1, param2, paramN)以及包圍在一對花括號{}中的函數主體時,就會發生函數聲明。

函數聲明會創建一個函數變量:一個與函數名稱同名的變量(例如,上一個示例中的sumA)。在當前作用域中(在函數聲明之前和之后),甚至在函數作用域本身內,都可以訪問該函數變量。

函數變量通常用于調用函數或將函數對象傳遞給其他函數(傳遞給高階函數)。

例如,編寫一個函數 sumArray(array),以遞歸方式累加一個數組的項(該數組可以包含數字或其他數組):

  1. sumArray([10, [1, [5]]]); // => 16 
  2.  
  3. function sumArray(array) { 
  4.   let sum = 0; 
  5.   for (const item of array) { 
  6.     sum += Array.isArray(item) ? sumArray(item) : item; 
  7.   } 
  8.   return sum
  9.  
  10. sumArray([1, [4, 6]]); // => 11 

動手試試:https://jsfiddle.net/dmitri_pavlutin/n7wcryuo/

function sumArray(array) { ... } 是函數聲明。

包含函數對象的函數變量sumArray在當前作用域中可用:sumArray([10, [1, [5]]])之前和sumArray([1, [4, 6]])之后,函數聲明, 以及函數本身的作用域sumArray([1, [4, 6]])(允許遞歸調用)。

由于提升,函數變量在函數聲明之前可用。

2.1 函數聲明的注意事項

函數聲明語法的作用是創建獨立函數。函數聲明應在全局作用域內,或直接在其他函數的作用域內:

  1. // Good! 
  2. function myFunc1(param1, param2) { 
  3.   return param1 + param2; 
  4.  
  5. function bigFunction(param) { 
  6.   // Good! 
  7.   function myFunc2(param1, param2) { 
  8.     return param1 + param2; 
  9.   } 
  10.  
  11.   const result = myFunc2(1, 3); 
  12.   return result + param; 

基于相同的原因,不建議在條件(if)和循環(while,for)中使用函數聲明:

  1. // Bad! 
  2. if (myCondition) { 
  3.   function myFunction(a, b) { 
  4.     return a * b; 
  5.   } 
  6. else { 
  7.   function myFunction(a, b) { 
  8.     return a + b; 
  9.   } 
  10.  
  11. myFunction(2, 3); 

使用函數表達式更好地執行有條件地創建函數。

3.函數表達式

當function關鍵字在表達式內部創建函數(帶有或不帶有名稱)時,將出現函數表達式。

以下是使用表達式創建的函數的示例:

  1. // Function expressions 
  2.  
  3. const sum = (function sumB(a, b) { 
  4.   return a + b; 
  5. }); 
  6.  
  7. const myObject = { 
  8.   myMethod: function() { 
  9.     return 42; 
  10.   } 
  11. }; 
  12.  
  13. const numbers = [4, 1, 6]; 
  14. numbers.forEach(function callback(number) { 
  15.   console.log(number); 
  16.   // logs 4 
  17.   // logs 1 
  18.   // logs 1 
  19. }); 

在函數表達式中創建了兩種函數:

  • 如果表達式中的函數沒有名稱,例如 function(){return 42},那是一個匿名函數表達式
  • 如果函數具有名稱,例如 上一個示例中的sumB和回調,那么這是一個命名函數表達式

3.1 函數表達式的注意事項

函數表達式適合作為條件創建的回調或函數:

  1. // Functions created conditionally 
  2. let callback; 
  3. if (true) { 
  4.   callback = function() { return 42 }; 
  5. else { 
  6.   callback = function() { return 3.14 }; 
  7.  
  8. // Functions used as callbacks 
  9. [1, 2, 3].map(function increment(number) { 
  10.   return number + 1; 
  11. }); // => [2, 3, 4] 

如果已創建命名函數表達式,請注意,該函數變量僅在創建的函數作用域內可用:

  1. const numbers = [4]; 
  2. numbers.forEach(function callback(number) { 
  3.   console.log(callback); // logs function() { ... } 
  4. }); 
  5.  
  6. console.log(callback); // ReferenceError: callback is not defined 

試一試:https://jsfiddle.net/dmitri_pavlutin/sujwmp10/2/

callback是一個命名的函數表達式,因此callback函數變量僅在callback()函數使用域可用,而在外部則不可用。

但是,如果將函數對象存儲到常規變量中,則可以在函數作用域內外從該變量訪問函數對象:

  1. const callback = function(number) { 
  2.   console.log(callback); // logs function() { ... } 
  3. }; 
  4.  
  5. const numbers = [4]; 
  6. numbers.forEach(callback); 
  7. console.log(callback); // logs function() { ... } 

試一試:https://jsfiddle.net/dmitri_pavlutin/1btmrcu2/1/

4. 總結

根據使用function關鍵字創建函數的方式,可以通過兩種方法來創建函數:函數聲明和函數表達式。

作者:Dmitri Pavlutin

譯者:前端小智 來源:dmitripavlutin原文:https://dmitripavlutin.com/javascript-function-expressions-and-declarations/

 

責任編輯:姜華 來源: 大遷世界
相關推薦

2011-05-30 16:11:46

Javascript

2017-08-01 00:19:15

Javascript函數函數聲明

2025-03-12 08:45:15

函數聲明函數表達式IIFE

2020-10-16 10:07:03

Lambda表達式Java8

2010-09-10 15:20:11

SQL函數計算表達式

2010-11-16 14:53:02

Oracle游標表達式

2023-11-02 18:45:00

Rust編程表達式

2011-05-11 17:40:30

PHP正則表達式

2021-07-28 15:28:22

JS逗號表達式面試題

2020-10-16 06:40:25

C++匿名函數

2009-08-31 17:11:37

Lambda表達式

2023-12-24 22:30:05

LambdaJava函數

2021-08-31 07:19:41

Lambda表達式C#

2012-04-28 15:22:46

PHP

2024-12-02 10:56:29

2009-08-10 10:06:10

.NET Lambda

2009-07-21 14:03:00

Scalaif表達式while循環

2009-10-12 10:11:08

Lambda表達式編寫

2009-09-16 09:58:53

PHP正則表達式函數

2009-09-16 10:43:22

PHP正則表達式函數
點贊
收藏

51CTO技術棧公眾號

久久久久亚洲av无码专区桃色| 无码中文字幕色专区| 亚洲一级av毛片| 欧美精品日韩| 亚洲男人天堂古典| 国产一级片自拍| 成人影院在线播放| 欧美国产一区二区在线观看| 91文字幕巨乱亚洲香蕉| 久久精品视频7| 我不卡神马影院| 亚洲国产日韩一区| 在线观看国产福利| а√在线中文网新版地址在线| 国产女同性恋一区二区| 国产精品污www一区二区三区| 中文字幕av久久爽| 国产一区二区高清| 九九久久久久久久久激情| 久久久久亚洲av无码a片| 中文无码日韩欧| 欧美日韩成人在线一区| 欧美日韩在线不卡视频| 久草在线新免费首页资源站| 中文av字幕一区| 欧美大香线蕉线伊人久久国产精品| 国产区精品在线| 日韩av成人高清| 国产91av在线| 国产真人真事毛片| 亚洲一区二区| 久久精品国产v日韩v亚洲 | 亚洲伊人精品酒店| 色久综合一二码| 成人av一级片| 高清视频在线观看三级| 亚洲在线免费播放| 欧美xxxx吸乳| 黄色av免费在线| 国产精品美女久久久久aⅴ国产馆| 国内精品久久国产| 精品人妻一区二区三区换脸明星| 美腿丝袜亚洲三区| 国产xxx69麻豆国语对白| 91看片在线播放| 99精品国产一区二区青青牛奶 | 男女做暖暖视频| 999久久久国产精品| 亚洲香蕉av在线一区二区三区| 午夜男人的天堂| 国产精品sss在线观看av| 日韩精品一区在线观看| 永久看看免费大片| 欧美中文高清| 欧美成人精品福利| 手机免费看av片| 国产乱论精品| 亚洲精品自拍偷拍| 国精产品一区一区三区免费视频| 秋霞在线一区| 亚洲欧美三级伦理| 少妇精品无码一区二区免费视频| 国产欧美日韩视频在线| 亚洲天堂影视av| 人成免费在线视频| 99久久精品网| 欧美日韩成人在线播放| 日本熟女一区二区| 西西裸体人体做爰大胆久久久| 日韩av手机在线观看| 波多野结衣黄色网址| 日韩av二区在线播放| 成人女保姆的销魂服务| 国产黄频在线观看| 99久久99久久久精品齐齐| 欧美日本韩国在线| aaa在线免费观看| 亚洲视频 欧洲视频| 成人污网站在线观看| 国产精品论坛| 欧美三级日韩三级国产三级| 久久精品久久99| 噜噜噜天天躁狠狠躁夜夜精品 | 波多野结衣在线网址| 欧美午夜一区二区福利视频| 欧美专区第一页| 中文字幕av网站| 成人黄色777网| 日本不卡二区| 欧美1—12sexvideos| 一本大道av一区二区在线播放| 另类小说色综合| 99精品中文字幕在线不卡 | 久久国产波多野结衣| 在线成人欧美| 国产区精品视频| 亚洲精品网站在线| 国产午夜精品美女毛片视频| 免费成人深夜夜行网站视频| 正在播放日韩精品| 91精品国产一区二区三区蜜臀| 国产av一区二区三区传媒| 久久99国内| 欧美精品18videos性欧| 伊人影院中文字幕| 97精品久久久午夜一区二区三区 | 久久视频一区| 成人高清在线观看| www.亚洲视频| 欧美日韩亚洲精品内裤| 亚洲一区二区在线视频观看| 西瓜成人精品人成网站| 美女少妇精品视频| 羞羞色院91蜜桃| 99精品欧美一区| 国产精品免费看久久久无码| 日韩一级二级| 亚洲精品一区二区三区婷婷月| 欧美国产日韩在线观看成人| 蜜桃视频一区二区三区| 久久久婷婷一区二区三区不卡| 超碰在线无需免费| 欧美午夜寂寞影院| 色无极影院亚洲| 99精品国产在热久久下载| 91九色单男在线观看| www 日韩| 欧美色窝79yyyycom| 久久精品国产亚洲av久| 亚洲日产国产精品| www.av一区视频| av免费在线观| 91精品国产一区二区三区| 91香蕉国产视频| 日本亚洲三级在线| 秋霞久久久久久一区二区| 在线看片国产福利你懂的| 亚洲丁香婷深爱综合| 久久久久久蜜桃| 国产成人aaaa| 久久手机在线视频| www.丝袜精品| 性日韩欧美在线视频| 成人爽a毛片一区二区| 亚洲一区二区三区中文字幕在线| 三年中文在线观看免费大全中国| 手机在线电影一区| 91精品免费久久久久久久久| 国产欧美久久久久久久久| 欧美久久一二区| 91视频青青草| 成人一级片网址| 国产日韩av网站| 国产精品丝袜在线播放| 91精品国产91久久久久久最新| 欧美 日韩 国产 在线| 亚洲第一久久影院| 超碰97在线资源站| 久久久久久夜| 亚洲一区二区三区四区中文| 久久久加勒比| 欧美成人激情视频免费观看| 午夜精品久久久久久久爽| 亚洲午夜三级在线| 99re久久精品国产| 天堂久久一区二区三区| 一区二区三区精品国产| 国产精品色婷婷在线观看| 欧美激情一区二区三区高清视频 | 无码视频一区二区三区| 国产精品色在线观看| 手机在线国产视频| 很黄很黄激情成人| 久久亚洲一区二区| 日韩电影精品| 欧美激情视频一区二区| 少妇一级淫片免费看| 色先锋资源久久综合| 久久精品日韩无码| 国产91精品一区二区麻豆网站| 大j8黑人w巨大888a片| 欧美日韩中文字幕一区二区三区| 国产精品1区2区在线观看| 黄色av网站在线播放| 亚洲精品99久久久久中文字幕| 日韩精品在线一区二区三区| 亚洲精品午夜久久久| 亚洲 欧美 日韩在线| 蜜桃视频一区二区| 乱人伦xxxx国语对白| 97精品国产| 国产一区二区三区黄| 国产精品久久久久77777丨| 久久久久国产精品免费| 国产在线视频你懂得| 精品国产不卡一区二区三区| 波多野结衣小视频| 亚洲一区二区三区美女| 日本人亚洲人jjzzjjz| 成人动漫av在线| 深夜黄色小视频| 国产亚洲在线| japanese在线播放| 欧美日韩性在线观看| 国产99午夜精品一区二区三区| 精品肉辣文txt下载| 97在线免费观看视频| 成人区精品一区二区不卡| 亚洲免费福利视频| 亚洲经典一区二区三区| 欧美日韩国产成人在线免费| 国产精品xxxx喷水欧美| 一区二区三区在线观看国产| 日韩视频在线观看免费视频| av一区二区三区四区| 欧美体内she精高潮| 免费的国产精品| 乱子伦视频在线看| 99精品视频免费观看| 日本福利视频在线观看| 99久久夜色精品国产亚洲1000部| 欧美一区二区在线视频观看| 欧美激情15p| 国产日韩欧美二区| 亚洲不卡视频| 91视频网页| 国产高清日韩| 国产在线精品成人一区二区三区| 在线观看精品| 国产91在线视频| 免费电影日韩网站| 欧美一区二区视频97| a级片在线免费| 久久久久久久影院| 青春草视频在线| 久久久久免费精品国产| 日韩激情av| 欧美激情精品久久久久久| 中文在线字幕免费观看| 欧美另类69精品久久久久9999| 在线免费观看污| 欧美精品在线免费播放| 26uuu亚洲电影在线观看| 久热精品视频在线免费观看 | 日韩久久精品网| 亚洲一卡二卡三卡| 97视频精品| 青青草影院在线观看| 欧美日韩一区自拍| 国产xxxx振车| 亚洲欧美日韩国产| 青青在线视频观看| 日本va欧美va欧美va精品| 三级视频中文字幕| 九九热在线视频观看这里只有精品| 久久99爱视频| 国产一区二区三区四| 亚洲欧美激情一区二区三区| 福利一区二区在线观看| 婷婷五月精品中文字幕| 久久你懂得1024| 国产午夜精品久久久久久久久| 中文字幕亚洲成人| 久久久久久福利| 动漫精品一区二区| 麻豆成人免费视频| 欧美日韩在线三级| japanese国产| 亚洲欧美国内爽妇网| 91caoporn在线| 欧美猛交免费看| 深夜av在线| 国产精品中文字幕在线| 亚洲精品18| 欧美日韩一区二区三| 久久久久免费av| 男女啪啪免费视频网站| 丝袜亚洲另类欧美综合| 亚洲av无日韩毛片久久| 93久久精品日日躁夜夜躁欧美| 在线视频第一页| 一区二区三区欧美久久| 国产尤物在线视频| 欧美老女人在线| 污污视频在线观看网站| 中文字幕自拍vr一区二区三区| 欧美韩日亚洲| 国产精品日韩在线| 成人高潮a毛片免费观看网站| 日本一区二区三区四区在线观看| 亚洲最大黄网| 37pao成人国产永久免费视频| 狠狠色丁香婷婷综合久久片| 亚洲少妇18p| 自拍偷拍亚洲综合| 亚洲永久精品在线观看| 日韩一区二区三区视频| 国产鲁鲁视频在线观看免费| 久久久久久久999精品视频| 国产69精品久久| 国产精品综合久久久久久| 国产在视频线精品视频www666| 欧美 国产 精品| 日韩电影在线一区| 国产女人18毛片水真多18| √…a在线天堂一区| 国产精品第5页| 精品国偷自产国产一区| 麻豆传媒在线完整视频| 国产精品成人一区| 久久精品国产亚洲5555| 六月婷婷激情网| 蜜臀av性久久久久蜜臀aⅴ四虎| bl动漫在线观看| 伊人开心综合网| 这里只有精品9| 国产亚洲aⅴaaaaaa毛片| 华人av在线| 国产手机精品在线| 一区二区三区午夜探花| 中文字幕第88页| 国产肉丝袜一区二区| 国产美女激情视频| 亚洲黄色www| 成人影音在线| 国产精品自拍首页| 欧美全黄视频| 日本黄色三级网站| 亚洲色图欧美在线| 国产又粗又猛又爽又黄视频 | 久久国产精品区| 中文字幕第20页| 日韩欧美成人精品| 少妇人妻一区二区| 国产69精品久久久| www.亚洲一二| 熟女少妇在线视频播放| 北条麻妃国产九九精品视频| 久久久久久久久久一区二区三区| 日韩欧美成人激情| 成人av影院在线观看| 福利视频一区二区三区| 精品成人久久| 国产精品一区二区人妻喷水| 精品国产1区2区| 偷拍精品一区二区三区| 欧美一二三视频| 九九热精品视频在线观看| 欧美黄色一级片视频| 久久久久99精品国产片| 做爰视频毛片视频| 色老头一区二区三区在线观看| 国产国产一区| 超碰97免费观看| 成人免费毛片高清视频| 日韩男人的天堂| 亚洲人成免费电影| jizz亚洲女人高潮大叫| 五月天综合婷婷| 成人黄页毛片网站| 免费看污视频的网站| 中文字幕国产亚洲2019| 9.1麻豆精品| 精品人妻人人做人人爽| 99久久综合国产精品| 91青青草视频| 久久国产一区二区三区| 97se亚洲| 日本va中文字幕| 最新国产精品久久精品| 黑人精品一区二区| 国产suv精品一区二区| 日韩国产一区二区三区| 激情av中文字幕| 日韩欧美亚洲范冰冰与中字| 在线激情小视频| 国产一区在线免费观看| 久久久久久穴| 欧美黄色免费在线观看| 亚洲人高潮女人毛茸茸| 欧美一区=区三区| 给我免费播放片在线观看| 国产欧美精品国产国产专区| 99久久精品国产一区二区成人| 国内精品久久久久久中文字幕| 国产精品一区二区av日韩在线| 色偷偷中文字幕| 欧美日韩黄色大片| 老司机午夜在线| 久久手机视频| 国产剧情一区在线| 亚洲毛片一区二区三区| 欧美成人一区在线| 你懂的视频欧美| www.欧美com| 欧美色视频在线观看| av在线私库| 午夜啪啪福利视频| 中文在线一区二区| 亚洲日本国产精品|