精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

日韩黄色精品视频| 久久精品免费网站| 97人妻人人澡人人爽人人精品| 久久国产亚洲精品| 日韩一区二区影院| 人妻夜夜添夜夜无码av| 九色在线播放| 久久精品国产成人一区二区三区| 美女999久久久精品视频| 美女网站视频在线观看| 午夜精品成人av| 成人欧美一区二区三区白人| 成人一区二区三区四区| 特黄视频免费看| 一区二区三区在线电影| 亚洲第一天堂无码专区| 91香蕉视频污版| 99se视频在线观看| 成人三级伦理片| 国产精品扒开腿爽爽爽视频| 欧美日韩亚洲国产另类| 久久99视频| 日韩免费高清视频| 99视频精品免费| 精精国产xxxx视频在线| 久久综合色之久久综合| 成人伊人精品色xxxx视频| 国产精品30p| 天天揉久久久久亚洲精品| 精品动漫一区二区三区在线观看| 久章草在线视频| ****av在线网毛片| 夜夜嗨av一区二区三区中文字幕| 亚洲一区免费看| 美女毛片在线看| 成人h精品动漫一区二区三区| 亚洲伊人久久综合| 国产精品丝袜黑色高跟鞋| 日本va欧美va欧美va精品| 97精品国产97久久久久久春色 | 亚洲欧美怡红院| 亚洲国产高清国产精品| 伦理片一区二区三区| 97成人超碰视| 久久精品成人一区二区三区蜜臀| 亚洲经典一区二区| 国产成人aaaa| 91免费在线观看网站| 国产欧美熟妇另类久久久| 久久99精品国产麻豆婷婷洗澡| 国产成人在线视频| 亚洲精品一区二区二区| 日韩av成人高清| 国产精品男人的天堂| 国产精品成人久久久| 日本午夜一本久久久综合| 日本中文字幕不卡免费| 色老头在线视频| 日韩av午夜在线观看| 国产精品视频yy9099| 中文在线观看av| 老司机午夜精品| 91精品视频免费| 99精品国产99久久久久久97| 国产91高潮流白浆在线麻豆| 国产精品区一区二区三含羞草| 免费看av毛片| 久久蜜桃一区二区| 亚洲春色在线视频| av在线看片| 午夜天堂影视香蕉久久| 男女高潮又爽又黄又无遮挡| 亚洲第一二三四区| 在线成人av影院| 国内精品免费视频| 伊人久久大香线蕉综合网站| 国产一区二区三区三区在线观看| 亚洲区一区二区三| 欧美日韩专区| 日本欧美爱爱爱| 中文字幕91爱爱| 国产精品18久久久久| 国产有色视频色综合| 国产黄色免费在线观看| 亚洲乱码精品一二三四区日韩在线| www.一区二区.com| 国产精品一二三产区| 欧美在线观看视频一区二区三区 | 精品久久毛片| 精品国产网站在线观看| 99久久人妻无码精品系列| 欧美日韩123| 久久国产天堂福利天堂| 69成人免费视频| 免费欧美在线视频| 国产高清自拍一区| 日韩在线资源| 精品欧美国产一区二区三区| 91插插插插插插插插| 伊人久久大香线蕉av超碰| 亚洲午夜女主播在线直播| 国语对白在线播放| 久久久久国产精品一区二区| 亚洲一区久久久| 国产免费av高清在线| 亚洲国产精品尤物yw在线观看| 99热手机在线| 国产精品自在线拍| 久久精品国产清自在天天线 | 黄页网站在线| 欧美日韩精品一区二区三区| 国产婷婷在线观看| 国产精品精品国产一区二区| 欧美亚洲成人免费| 午夜精品久久久久久久91蜜桃| 国产欧美日韩综合精品一区二区| 加勒比成人在线| 成人影院网站ww555久久精品| 亚洲精品视频在线观看视频| 久草国产在线视频| 韩国av一区二区| 奇米视频888战线精品播放| 免费在线国产视频| 51精品视频一区二区三区| 美女爆乳18禁www久久久久久| 伊人精品视频| 北条麻妃高清一区| 超碰在线caoporn| 欧美久久久久久久久中文字幕| 国产成人福利在线| 亚洲永久免费精品| 久久一区二区三区欧美亚洲| 蜜桃传媒在线观看免费进入| 欧美一级一区二区| 欧美偷拍第一页| 国产一区999| 美国av在线播放| **精品中文字幕一区二区三区| 国产一区二区激情| 在线观看日本网站| 91农村精品一区二区在线| 国产手机免费视频| 99re8这里有精品热视频免费 | 亚洲欧美国产日韩天堂区| 国产精品国产三级国产专区52| av亚洲精华国产精华精| 欧美 日韩 亚洲 一区| 国产人妖ts一区二区| 久久久久久久久中文字幕| 免费观看的毛片| 精品久久久视频| 精品久久久久久中文字幕人妻最新| 一本色道久久综合| 鲁鲁狠狠狠7777一区二区| 伊人成综合网站| 亚洲最大中文字幕| 一区二区三区精| 欧美激情一区二区三区不卡| 91亚洲精品久久久蜜桃借种| 亚洲乱码免费伦视频| 91在线精品观看| 俺来也官网欧美久久精品| 日韩精品在线第一页| 国产欧美一区二区三区在线看蜜臂| 久久综合九色综合久久久精品综合| 乱子伦视频在线看| 99视频精品全国免费| 97超碰人人看人人| 久草在线中文最新视频| 亚洲欧美日韩国产中文专区| 中文字幕人成人乱码亚洲电影| 亚洲欧美日韩在线不卡| 国产精品久久久久久在线观看| 亚洲综合精品四区| 亚洲三区在线| 大型av综合网站| 国产va免费精品高清在线观看| 免费黄网在线观看| 91精品国产色综合久久不卡蜜臀| 国产一级一片免费播放放a| av亚洲精华国产精华精| 另类小说色综合| 国产精品99一区二区| 欧美日韩一区综合| 亚洲欧洲一二区| 午夜精品视频在线| 日本中文字幕在线看| 亚洲国产精品成人一区二区| 国产真人无遮挡作爱免费视频| 亚洲欧美日韩国产另类专区| 亚洲调教欧美在线| 国内成人精品2018免费看| 国产精品入口芒果| 日韩在线精品| 国偷自产av一区二区三区小尤奈| 成人精品国产亚洲| 97精品一区二区三区| 91露出在线| 日韩精品在线第一页| 97人妻精品一区二区三区动漫| 精品日本高清在线播放| 91香蕉视频污在线观看| 99久久久国产精品免费蜜臀| 天天综合成人网| 久久在线精品| 欧美一级欧美一级| 久久久久美女| 日韩欧美亚洲在线| 久久国产精品免费精品3p| 成人久久一区二区三区| 欧美一区 二区 三区| 欧美激情一级二级| 免费a级人成a大片在线观看| 亚洲精品久久久久久久久久久久| 国产日韩欧美一区二区东京热| 色婷婷精品大在线视频| 国产精品成人久久| 亚洲精品写真福利| 国产小视频你懂的| 中文字幕不卡在线| 国产精品无码一区二区三区免费| 成人深夜福利app| 日韩高清一二三区| 国产尤物一区二区| 鲁一鲁一鲁一鲁一av| 久久综合影音| 日韩视频第二页| 一本色道久久综合亚洲精品不| 日本黄色片一级片| 欧美搞黄网站| 日本精品免费视频| 亚洲精品在线观看91| 在线不卡日本| 91精品国产乱码久久久久久| 亚洲国产日韩欧美| 久久人人99| 亚洲日本一区二区三区在线不卡| 日韩激情一区| 亚洲精品日韩在线观看| 日韩不卡一区| 一区在线电影| 亚洲国产老妈| 大片在线观看网站免费收看| 亚洲一区色图| 黄色一级片国产| 好看的日韩av电影| 草b视频在线观看| 99在线热播精品免费99热| 免费在线观看视频a| 99综合视频| av天堂永久资源网| 三级影片在线观看欧美日韩一区二区 | 日韩乱码人妻无码中文字幕久久| 91丨porny丨蝌蚪视频| 少妇户外露出[11p]| 久久综合九色综合97婷婷女人| 波多野结衣一本| 国产视频一区二区在线观看| 国产18无套直看片| 亚洲三级在线看| 久久综合综合久久| 黑人欧美xxxx| 国产精品国产精品国产| 欧美日本一道本| 国产99对白在线播放| 亚洲国产精品女人久久久| 日韩av高清在线| 中文字幕精品av| bestiality新另类大全| 久久久久这里只有精品| 澳门成人av网| 成人黄色激情网| youjizzjizz亚洲| 欧美日韩另类综合| 天堂美国久久| 青青草国产精品视频| 久久亚洲风情| 三级av免费看| 91在线你懂得| 国产麻豆视频在线观看| 亚洲国产综合色| 中文字幕久久久久| 精品国内二区三区| 国产人成在线观看| 欧美激情精品久久久久久大尺度| 久久毛片亚洲| 666精品在线| 精品久久成人| 日韩视频 中文字幕| 国产欧美大片| 在线免费看v片| 2023国产一二三区日本精品2022| 亚洲视频重口味| 欧美日韩综合视频网址| 国产免费叼嘿网站免费| 日韩av一区在线| 国产三级在线播放| 国产99视频在线观看| 一区二区三区在线免费看 | 欧美激情五月| 校园春色 亚洲色图| 97精品电影院| 久久久久久久久久久网| 欧美日韩一区国产| 三级视频网站在线| 九九九久久久久久| 久久精品黄色| 欧美一二三区| 亚洲日本欧美| 人妻体体内射精一区二区| 国产日韩一级二级三级| 久久露脸国语精品国产91| 欧美一区二区三区在线电影| avtt亚洲| 国产精品福利网| 台湾色综合娱乐中文网| 日韩精品综合在线| 国产精品一区二区三区网站| 又嫩又硬又黄又爽的视频| 色综合色综合色综合色综合色综合| 国产激情视频在线播放| 精品国产一区av| www.久久.com| 日韩欧美在线一区二区| 免费永久网站黄欧美| 亚洲av熟女高潮一区二区| 亚洲人成网站在线| 艳妇乳肉豪妇荡乳av| 中文字幕亚洲激情| 成人免费一区| 亚洲 国产 欧美一区| 久久婷婷激情| wwwwxxxx国产| 日韩欧美亚洲一二三区| 日中文字幕在线| 欧美一区二三区| 亚洲综合图色| 日韩欧美在线免费观看视频| 久久久久久免费网| 无码人妻丰满熟妇区bbbbxxxx| 精品亚洲一区二区三区在线播放| 国产高清自产拍av在线| 九色一区二区| 久久午夜精品一区二区| 高潮毛片无遮挡| 在线观看免费成人| aaa日本高清在线播放免费观看| 国产精品久久久久影院日本 | 最近更新的2019中文字幕| 69堂精品视频在线播放| 亚洲国产欧洲综合997久久 | 91在线|亚洲| 欧美国产精品| 亚洲高清无码久久| 日韩欧美国产骚| 都市激情一区| 成人久久精品视频| 韩日在线一区| 18禁裸乳无遮挡啪啪无码免费| 91黄色免费看| 午夜视频在线看| 99视频在线播放| 9色国产精品| 亚洲天堂av中文字幕| 51午夜精品国产| av免费在线视| 视频在线精品一区| 精品无人码麻豆乱码1区2区 | 日本成人精品视频| 日韩一区二区免费在线观看| 91九色在线看| 清纯唯美一区二区三区| 久久爱另类一区二区小说| 欧产日产国产v| 日韩高清免费观看| 日韩一级二级| 日韩精品一区二区三区四| 久久综合一区二区| 国产又粗又猛又爽又黄的| 欧美高清在线播放| 国模精品一区| 日韩精品在线播放视频| 欧美视频专区一二在线观看| 午夜伦全在线观看| 国产精品久久久久久久久久直播 | 视频这里只有精品| 日韩黄在线观看| 一区在线不卡| 37pao成人国产永久免费视频| 国产精品高清亚洲| 无码精品人妻一区二区| 成人精品福利视频| 亚洲在线观看| 欧美国产精品一二三| 一区二区三区四区精品| 国产精品chinese在线观看| 黄大色黄女片18第一次| 精品久久久精品| 成人短视频在线| 亚洲精品一区二|