亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript函數式編程(Functional Programming)組合函數(Composition)用法分析

2019-11-19 11:30:02
字體:
來源:轉載
供稿:網友

本文實例講述了JavaScript函數式編程(Functional Programming)組合函數(Composition)用法。分享給大家供大家參考,具體如下:

組合(Composition)函數,就是把兩個或以上的函數組合到一塊兒,整成一個新的函數。我找到了一個很好的例子,很好地解釋了組合函數這個概念。

比如一個應用主要是記錄一下日常的花銷(expenses),應用里的數據看起來像這樣:

const expenses = [ {  name: '租金',  price: 3000,  type: '日常' },  {  name: '阿里云服務',  price: 600,  type: '服務' },  {  name: '健身中心',  price: 50,  type: '健康' },  {  name: '水電',  price: 100,  type: '日常' }];

合計花銷

現在我要合計一下所有花銷,創建一個函數,用一下 map 與 reduce,這個函數像這樣:

const sum = (source) =>  source  .map((item) => item.price)  .reduce((accumulator, price) => accumulator + price, 0)

sum 這個函數接收一個 source 參數,在函數里,先用 map,返回 source 里的所有的 price(價格)。然后再用 reduce 去處理返回的 price ,這里就是合計所有的 price 的值。

這個函數用起來像這樣:

let total = sum(expenses) // 結果:3750

組合

現在我要合計一下我在某個類別下花的錢。比如我要合計一下 “日?!?這個分類里花的錢。先創建一個函數,可以返回所有 “日?!?類型的花銷。

const = getHousehold = (source) => { return source.filter((item) => item.type === '日常')}

getHousehold 函數里用了 filter ,它可以過濾出滿足特定條件的項目。這里就是把 type 的值是 “日?!?的項目過濾出來。

現在如果我想得到 “日?!?類型的花銷的合計的結果,可以這樣:

let householdExpenses = sum(getHousehold(expenses)) // 結果:3100

上面,我們先用 getHousehold 函數得到所有的 “日?!?類型的項目,然后又用 sum 函數合計了得到的結果。最終返回的就是所有 “日常” 類型的項目的合計花銷。

根據上面的使用,我們可以去創建一個組合函數,這個函數可以去合計 “日常” 類型的項目的花銷。先創建一個組合函數用的函數:

const compose = (function1, function2) => { return (source) => function2(function1(source))}

現在我們可以用創建的這個 compose 函數去組合兩個函數:

const sumHousehold = compose(getHousehold, sum)

sumHousehold 就是一個組合,它組合了 getHousehold 還有 sum?,F在如果你提供給 sumHousehold 一組數據,比如最開始我們定義的 expenses,首先會用 getHousehold 得到所有 “日?!?類型的項目,然后再用 sum 去合計這些項目。

sumHousehold(expenses)

新任務

我現在要得到花銷數據里的所有的分類:

const getCategories = (source) => { return source.map((item) => item.type)}

用一下這個函數:

getCategories(expenses)// ["日常", "服務", "健康", "日常"]

在返回的結果里,“日常” 這個分類出現了兩次。我們再去創建一個函數可以得到唯一的項目:

const uniqueElement = (source) => { return source.filter((item, position) => {  return source.indexOf(item) === position })}

現在我們再去創建一個組合函數:

const uniqueCategories = compose(getCategories, uniqueElement)

uniqueCategories 這個函數組合了 getCategories 還有 uniqueElement 函數。你交給 uniqueCategories 的數據,會先被 getCategories 處理,它會得到所有的分類,然后這些分類又會被 uniqueElement 處理,這個函數可以得以唯一的項目。

uniqueCategories(expenses)// ["日常", "服務", "健康"]

完整的代碼

// 應用里的數據const expenses = [ {  name: '租金',  price: 3000,  type: '日常' }, {  name: '阿里云服務',  price: 600,  type: '服務' }, {  name: '健身中心',  price: 50,  type: '健康' }, {  name: '水電',  price: 100,  type: '日常' }];// 合計數據里的 priceconst sum = (source) => source  .map((item) => item.price)  .reduce((accumulator, price) => accumulator + price, 0)// 得到數據里類型是 “日?!?的所有項目const getHousehold = (source) => source  .filter((item) => item.type === '日常')// 合計結果let total = sum(expenses)console.log(total)// 合計 “日?!?類型的花費let householdExpenses = sum(getHousehold(expenses))console.log(householdExpenses)// 創建組合函數用的函數const compose = (function1, function2) => { return (source) => function2(function1(source))}// 創建一個組合函數,可以合計 “日常” 類型的花費const sumHousehold = compose(getHousehold, sum)console.log(sumHousehold(expenses))// 得到數據里的所有分類const getCategories = (source) => { return source.map((item) => item.type)}console.log(getCategories(expenses))// 返回一個數組里的唯一元素const uniqueElement = (source) => { return source.filter((item, position) => {  return source.indexOf(item) === position })}// 創建一個組合函數,可以返回數據里的唯一分類const uniqueCategories = compose(getCategories, uniqueElement)console.log(uniqueCategories(expenses))

更多關于JavaScript相關內容可查看本站專題:《JavaScript常用函數技巧匯總》、《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》及《JavaScript數學運算用法總結

希望本文所述對大家JavaScript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧洲美女免费图片一区| 久久久久国产精品www| 成人精品视频久久久久| 久久久国产一区| 国产中文字幕91| 成人春色激情网| 国产欧美日韩91| 久久免费视频在线观看| 欧美成aaa人片在线观看蜜臀| 久久久亚洲精品视频| 日韩美女中文字幕| 欧美专区在线播放| 国产欧美精品va在线观看| 日韩欧美在线中文字幕| 亚洲精品色婷婷福利天堂| 日韩欧美黄色动漫| 国产精品久久精品| 久久久久久久久久av| 亚洲欧美综合图区| 亚洲成人精品久久久| 亚洲精品mp4| 国产精品一区二区av影院萌芽| 久久久久久国产精品三级玉女聊斋| 精品女厕一区二区三区| 欧美高清无遮挡| 亚洲女人天堂色在线7777| 精品久久久久久久久久久久| 国产精品国产福利国产秒拍| 91香蕉嫩草影院入口| 国产精品久久久久久久久免费| 亚洲第一区在线| 一道本无吗dⅴd在线播放一区| 亚洲性av在线| 欧美黑人极品猛少妇色xxxxx| 亚洲欧洲日产国产网站| 欧美精品激情blacked18| 91高潮在线观看| 久久激情五月丁香伊人| 久久九九全国免费精品观看| 色婷婷综合久久久久中文字幕1| 国产日韩欧美自拍| 深夜成人在线观看| 国产视频欧美视频| 亚洲精品狠狠操| 91久热免费在线视频| 日韩中文字幕在线视频播放| 91精品国产91久久久久久吃药| 午夜精品理论片| 欧美性猛交xxxx| 国产精品一二区| 成人免费激情视频| 亚洲三级黄色在线观看| 欧美国产日韩一区| 亚洲va国产va天堂va久久| 久久精品电影网站| 日韩免费在线视频| 亚洲一级片在线看| 91精品视频播放| 欧美中文在线字幕| 国产精品欧美激情| 久久色精品视频| 欧美一区三区三区高中清蜜桃| 不卡av在线播放| 亚洲人成网站免费播放| 5566成人精品视频免费| 欧美成人免费一级人片100| 国产成人极品视频| 亚洲欧洲高清在线| 亚洲欧美一区二区三区情侣bbw| 欧美日产国产成人免费图片| 一区二区欧美在线| 性日韩欧美在线视频| 性亚洲最疯狂xxxx高清| 亚洲国产精品久久91精品| 久久久久久亚洲| 久久久999精品免费| 亚洲精品视频在线观看视频| 国产成人精品综合久久久| 九九热精品在线| 久久久久久亚洲精品| 在线播放国产一区中文字幕剧情欧美| 亚洲精品自拍偷拍| 国产精品久久久久久久久久ktv| 国产小视频91| 精品视频一区在线视频| 久久精品国产v日韩v亚洲| 久久久久久久香蕉网| 欧美高跟鞋交xxxxxhd| 亚洲男人天天操| 欧美第一黄色网| 国产成人精品a视频一区www| 国产69精品久久久久久| 亚洲专区国产精品| 国产精品欧美激情在线播放| 成人在线中文字幕| 久久香蕉国产线看观看av| 最新91在线视频| 欧美激情手机在线视频| 伦伦影院午夜日韩欧美限制| 日韩精品在线播放| 欧美日韩亚洲成人| 亚洲激情视频在线观看| 欧美激情三级免费| 九九热最新视频//这里只有精品| 久久亚洲精品网站| 热99精品里视频精品| 福利视频一区二区| 国产精品永久在线| 日韩成人av网址| 伊人久久久久久久久久久久久| 亚洲美女黄色片| 亚洲美女自拍视频| 亚州欧美日韩中文视频| 亚洲一区www| 久久视频免费在线播放| 久久精品国产成人| 国产99视频精品免视看7| 中文字幕视频一区二区在线有码| 亚洲va电影大全| 91在线|亚洲| 亚洲男人天堂2024| 亚洲在线视频观看| 欧美寡妇偷汉性猛交| 精品国产欧美一区二区三区成人| 亚洲欧洲午夜一线一品| 欧美猛交免费看| 亚洲天堂视频在线观看| 在线日韩精品视频| 久久夜精品香蕉| 日韩有码视频在线| 91亚洲国产成人精品性色| 91夜夜揉人人捏人人添红杏| 综合国产在线视频| 午夜精品福利视频| 久久精品人人做人人爽| 91超碰中文字幕久久精品| 琪琪亚洲精品午夜在线| 亚洲一区中文字幕在线观看| 日本高清不卡在线| 欧美乱大交xxxxx另类电影| 欧美国产欧美亚洲国产日韩mv天天看完整| 国产精品一区二区三| 国产精品丝袜高跟| 国产精品成人aaaaa网站| 欧美最猛性xxxxx(亚洲精品)| 亚洲女在线观看| 久久久久久久久亚洲| 91手机视频在线观看| 777国产偷窥盗摄精品视频| 久久久久久伊人| 91精品国产沙发| 久久免费精品日本久久中文字幕| 国产精品国产三级国产专播精品人| 97久久精品在线| www.亚洲成人| 91丨九色丨国产在线| 国产日韩在线视频| 91精品久久久久久久久中文字幕| 中文字幕亚洲第一| 亚洲人成亚洲人成在线观看| 国产亚洲精品成人av久久ww| 中文字幕国产精品久久| 精品久久久91| 日本欧美一级片|