亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript前端面試組合函數(shù)

 更新時間:2022年06月16日 11:30:45   作者:掘金安東尼  
這篇文章主要為大家介紹了JavaScript前端面試組合函數(shù)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

經(jīng)歷過一些列的函數(shù)式編程思想的學(xué)習(xí)總結(jié),一些重要的高階函數(shù)的學(xué)習(xí),以及前一段時間關(guān)于 RxJS 的學(xué)習(xí)。

我們再回看一次 —— 組合函數(shù) compose

本瓜越來越覺得,【易讀】的代碼應(yīng)該是將聲明和調(diào)用分開來的。根據(jù)不同的流程,用函數(shù)組合的方式、也可以說它是管道、或者說是鏈式調(diào)用,將聲明的函數(shù)組合起來,再等待時機進行調(diào)用。

如果沒有組合函數(shù) compose,函數(shù)連續(xù)調(diào)用將會是嵌套的:

const multi10 = function(x) { return x * 10; }
const toStr = function(x) { return `${x}`; }
const compute = function(x){ 
    return toStr(multi10(x))
}
compute(8)

fn3(fn2(fn1(fn0(x)))),層層嵌套是很容易看錯的;

所以,必須嘗試將調(diào)用層級扁平化!

compose 應(yīng)運而生,它大概就會是這樣:

const compose = function(f,g) { 
    return function(x) { 
        return f(g(x))
    }
}
let compute = compose(toStr, multi10)
compute(8)

通過使用compose函數(shù)我們可以把兩個函數(shù)組合成一個函數(shù),這讓代碼從右往左執(zhí)行,而不是層層計算某個函數(shù)的結(jié)果作為另一個函數(shù)的參數(shù),這樣代碼也更加直觀。

當(dāng)然,我們不能讓 compose 限制于只能處理連續(xù)調(diào)用兩個函數(shù),于是支持任意參數(shù)版本的 compose 將是這樣的:

function compose(...funs){ 
    return (x) =>funs.reduce((acc, fun) => fun(acc), x) 
}

通過函數(shù)組合,我們可以可以聲明式地指定函數(shù)間的關(guān)系,代碼的可讀性也大大提高,也方便我們后續(xù)對代碼進行擴展跟重構(gòu);

而且在React里面,當(dāng)我們的高階組件變多的時候,一個套著一個就很難看,我們就可以通過類似的方式來讓我們的高階組件層級扁平化;

這就是最最原始的 compose,以及它被提出的原始動機~~

以上就是JavaScript前端面試組合函數(shù)的詳細內(nèi)容,更多關(guān)于JavaScript組合函數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論