成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

聊聊 Javascript 常見的高階函數

開發 前端
高階函數,英文叫 Higher Order function。一個函數可以接收另外一個函數作為參數,這種函數就叫做高階函數。

[[422538]]

高階函數,英文叫 Higher Order function。一個函數可以接收另外一個函數作為參數,這種函數就叫做高階函數。

示例:

  1. function add(x, y, f) { 
  2.  return f(x) + f(y); 
  3.  
  4. //用代碼驗證一下: 
  5. add(-5, 6, Math.abs); // 11 

一、常見的高階函數

ES6中數組新增了幾種方法,其中 map、reduce、filter 幾個都是高階函數,除此,普通的sort也是高階函數。分別介紹下新增的三個方法。

1.1、filter

filter 是過濾數組,返回滿足條件的數據,組成一個新的數組返回,不滿足條件的被丟棄。

實例1:取出數組中小于 100 的數據,放到一個新數組中

  1. let grad = [ 102, 188, 55, 66, 200, 800 ] 
  2. let arr2 = grad.filter( function(item){ 
  3.  return item <= 100 
  4. }) 
  5. console.log("arr2",arr2)// 55, 66 

 上述實例中,filter傳入的參數是一個函數,傳入的函數依次作用于每個元素,然后根據返回值是 true 或 false 決定保留還是丟棄元素。因為只有 55 66 兩個滿足條件,所以新的數組中只有這兩個元素。

1.2、map

map 是映射的意思。

原數組被映射成一個新的數組,返回值是一個新數組,不改變原來的數組。新的數組與原數組的長度是不會改變的。

實例2:給數據每個元素放大 2 倍。

  1. let arr2 = [ 55, 66 ] 
  2. let arr3 = arr2.map( item => { 
  3.  return item*2 
  4. }) 
  5. //返回結果 [ 110, 132 ] 

 上述實例,map接收的參數是一個函數,該函數依次作用于每個元素,對元素放大了2倍,也可以對其進行任意的復雜操作。

1.3、reduce

reduce 是對數組進行匯總的,往往進去一個數組,出來是一個數據。經常用于求和和計算平均值。

實例3:對上個實例返回的結果進行求和。

  1. let sum = arr3.reduce((tmp,item)=>{ 
  2.  return tmp+item 
  3. }) 
  4. //返回結果 242 

 重點來了,如果我們想把上邊三個實例合并到一起執行,最終我們可以寫得有多簡單呢?

  1. // 復雜寫法 
  2. let grad = [102,188,55,66,200,800] 
  3. let arr2 = grad.filter(function(item){ 
  4.  return item <= 100 
  5. }) 
  6. let arr3 = arr2.map(item=>{ 
  7.  return item*2 
  8. }) 
  9. let sum = arr3.reduce((tmp,item)=>{ 
  10.  return tmp+item 
  11. }) 
  12.  
  13. //簡單寫法 
  14. let sum2 = grad 
  15.            .filter( item => {return item <= 100}) 
  16.           .map(item=>{return item*2}) 
  17.           .reduce((tmp,item)=>{return tmp+item}) 

 

責任編輯:姜華 來源: 今日頭條
相關推薦

2021-05-28 08:52:45

Hive分析函數

2022-08-24 14:14:58

JavaScript函數

2021-10-09 07:10:30

JavaScriptBigIn函數

2021-01-22 07:48:07

JavaScript 高階函數閉包

2023-11-28 09:19:12

2022-01-04 06:50:12

數據摘要方法

2022-02-09 11:02:16

JavaScript前端框架

2021-10-17 22:40:51

JavaScript開發 框架

2021-01-07 07:53:10

JavaScript內存管理

2022-03-17 08:34:47

TypeScript項目類型

2015-04-08 10:27:43

JavaScript字符串操作函數

2024-06-26 13:11:40

2022-02-07 21:49:19

串行通信UART

2022-03-30 09:01:37

CSS屬性函數

2024-07-18 15:08:27

2019-07-23 15:04:54

JavaScript調用棧事件循環

2021-06-02 09:01:19

JavaScript 前端異步編程

2022-01-04 12:19:12

自動駕駛系統開發

2020-03-31 09:09:48

Web安全網絡攻擊DDOS

2020-11-09 07:25:20

函數 JavaScript數據
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 尤物在线视频 | 日韩精品免费视频 | 亚洲综合视频 | 乱一性一乱一交一视频a∨ 色爱av | 毛片一区二区三区 | 亚洲视频一区二区三区 | 午夜欧美a级理论片915影院 | 男女网站免费 | 国产99视频精品免费播放照片 | 欧美激情欧美激情在线五月 | 亚洲成年在线 | 91成人免费电影 | 亚洲视频中文字幕 | 亚洲精品在线视频 | 亚洲成人精品久久久 | 精品久久久久久亚洲综合网 | 久久久www成人免费无遮挡大片 | 久久一区| 欧美视频精品 | 国产一二三区在线 | 久久国产精品视频免费看 | 亚洲高清视频在线 | 欧美一区二区三区免费在线观看 | 国产亚洲欧美日韩精品一区二区三区 | a欧美| 一区二区三区精品 | 亚洲成人一区二区三区 | 丁香六月伊人 | 波多野结衣精品 | 国产精品1区 | 国产精品二区三区 | 欧美日韩不卡 | 91精品国产91久久久久青草 | 国产精品海角社区在线观看 | 九九热最新地址 | 一区二区不卡视频 | 99免费在线观看 | 欧美精品在欧美一区二区 | 欧美久久国产 | 日韩精品免费视频 | 伊人网伊人 |