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

JavaScript函數(shù)式編程(Functional Programming)高階函數(shù)(Higher order functions)用法分析

 更新時間:2019年05月22日 09:13:14   作者:longzhoufeng  
這篇文章主要介紹了JavaScript函數(shù)式編程(Functional Programming)高階函數(shù)(Higher order functions),結(jié)合實例形式分析了javascript函數(shù)式編程高級函數(shù)的概念、原理、用法及相關(guān)操作注意事項,需要的朋友可以參考下

本文實例講述了JavaScript函數(shù)式編程(Functional Programming)高階函數(shù)(Higher order functions)用法。分享給大家供大家參考,具體如下:

高階函數(shù)(higher-order functions),就是返回其它函數(shù)的函數(shù),或者使用其它函數(shù)作為它的參數(shù)的函數(shù)。

使用函數(shù)作為參數(shù)

因為函數(shù)本身就是一個值,所以可以讓函數(shù)作為參數(shù)傳遞給其它的函數(shù)。JavaScript 有些函數(shù)就需要用到函數(shù)類型的參數(shù),比如 Array.map。

比如我有一組數(shù)據(jù):

const names = ['小貓', '小狗', '小刺猬']

我要分別問候一下這組數(shù)據(jù)里的每個項目:

const greetings = names.map(function(name) {
 return `hi ~ ${name}`
})
console.log(greetings)
// ["hi ~ 小貓", "hi ~ 小狗", "hi ~ 小刺猬"]

上面的 map 方法里用了一個匿名函數(shù)作為它的參數(shù)。在這個函數(shù)里面,我們在數(shù)組里的每個項目的前面都加上了一個 “hi ~” ,map 會返回一個新的數(shù)組,這個數(shù)組我交給了 greetings 變量。

用箭頭函數(shù)會更簡潔一些:

const greetings = names.map(name => `hi ~ ${name}`)

高階函數(shù)

高階函數(shù)(higher-order functions)。在 JavaScript 里面,函數(shù)跟普通的對象沒啥大區(qū)別,所以你可以讓函數(shù)作為參數(shù)傳遞到其它的函數(shù)里面,你也可以在函數(shù)里返回函數(shù)。使用函數(shù)作為參數(shù)的函數(shù),或者返回函數(shù)的函數(shù),這些函數(shù)被稱為高階函數(shù)(higher-order functions)。

比如剛才我們用的 map 就是一個高階函數(shù),因為它會用到一個函數(shù)作為它的參數(shù)。

再看一個例子:

const robot = (name, action) => {
 return action(name)
}
const greet = (name) => {
 return `hello, ${name}`
}
const greeting = robot(' 您好 ', greet)
// 返回 “ hello, 您好 ”

robot 是個函數(shù),它支持兩個參數(shù),name 與 action,這里的 action 參數(shù)的類型是一個函數(shù)。在 robot 里面返回了 action ,并且把 name 參數(shù)的值交給了 action。接下面我們又定義了一個函數(shù)叫 greet,它接受一個參數(shù)是 name ,這個函數(shù)會返回一個字符串。

然后我們用了一下 robot 這個函數(shù),設(shè)置了一下它的兩個參數(shù)的值,name 參數(shù)的值是 ' 您好 ‘,action 參數(shù)的值是我們定義的 greet 這個函數(shù)。執(zhí)行的結(jié)果就會是:

hello, 您好

我們可以再去定義一下函數(shù):

const goodbye = (name) => {
 return `bye, ${name}`
}

然后再用一下 robot 函數(shù):

const byeBye = robot(' 您好 ', goodbye)

這次會返回:

bye, 您好

完整的例子:

const robot = (name, action) => {
 return action(name)
}
const greet = (name) => {
 return `hello, ${name}`
}
const greeting = robot(' 您好 ', greet)
console.log(greeting)
const goodbye = (name) => {
 return `bye, ${name}`
}
const byeBye = robot(' 您好 ', goodbye)
console.log(byeBye)

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)

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

相關(guān)文章

  • jQuery中deferred對象使用方法詳解

    jQuery中deferred對象使用方法詳解

    這篇文章主要為大家詳細介紹了jQuery中deferred對象使用方法,也就是延遲對象的使用方法,感興趣的小伙伴們可以參考一下
    2016-07-07
  • js防刷新的倒計時代碼 js倒計時代碼

    js防刷新的倒計時代碼 js倒計時代碼

    這篇文章主要為大家詳細介紹了js防刷新的倒計時代碼,js倒計時的實現(xiàn)代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-09-09
  • 微信小程序?qū)崿F(xiàn)轉(zhuǎn)盤抽獎

    微信小程序?qū)崿F(xiàn)轉(zhuǎn)盤抽獎

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)轉(zhuǎn)盤抽獎,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • JavaScript刪除對象的不必要的屬性

    JavaScript刪除對象的不必要的屬性

    這篇文章主要給大家介紹了JavaScript刪除對象的不必要的屬性,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-10-10
  • TBCompressor js代碼壓縮

    TBCompressor js代碼壓縮

    公司原先的JS和CSS文件都是用在線壓縮程序壓縮的,看似方便,但很容易出錯,可能是壓縮程序把CSS里面的一些Hack語句給混淆了,于是我決定用大名鼎鼎的YUI compressor。
    2011-01-01
  • Ubuntu 11.10 安裝Node.js的方法

    Ubuntu 11.10 安裝Node.js的方法

    Ubuntu 11.10 安裝Node.js的方法,需要的朋友可以參考下。
    2011-11-11
  • 談?wù)凧S中常遇到的瀏覽器兼容問題和解決方法

    談?wù)凧S中常遇到的瀏覽器兼容問題和解決方法

    這篇文章主要介紹了談?wù)凧S中常遇到的瀏覽器兼容問題和解決方法 ,有些代碼在某些瀏覽器的某些版本中表現(xiàn)出不兼容,影響頁面的體驗;這時就需要處理了這些兼容問題,讓頁面在多個版本的瀏覽器上運行良好。
    2016-12-12
  • prototype框架中美元符號$用法分析

    prototype框架中美元符號$用法分析

    這篇文章主要介紹了prototype框架中美元符號$用法,結(jié)合實例形式較為詳細的分析了$符號的使用技巧與相關(guān)注意事項,需要的朋友可以參考下
    2016-01-01
  • javascript模擬的Ping效果代碼 (Web Ping)

    javascript模擬的Ping效果代碼 (Web Ping)

    JS雖然發(fā)送不了真正Ping的ICMP數(shù)據(jù)包,但Ping的本質(zhì)仍然是請求/回復(fù)的時間差,HTTP自然可以實現(xiàn)此功能.
    2011-03-03
  • 實例解析ES6 Proxy使用場景介紹

    實例解析ES6 Proxy使用場景介紹

    本篇文章主要介紹了ES6 Proxy使用場景介紹,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01

最新評論