摘要:還是上面函數(shù)的例子,我們希望實(shí)現(xiàn)下面的形式在下一節(jié)具體實(shí)現(xiàn)部分應(yīng)用只傳遞了第一個參數(shù)分析上面的代碼可知,實(shí)現(xiàn)部分應(yīng)用的關(guān)鍵是部分應(yīng)用的返回結(jié)果是一個新的函數(shù)該函數(shù)可以被傳入其他參數(shù)再次調(diào)用柯里化現(xiàn)在進(jìn)入正題,前面講完了部分應(yīng)用。
前言
(話不多說,填之前的坑)
正文 引子-從apply說函數(shù)應(yīng)用在js里,我們對于function的用法,可能大部分情況下都還是處于調(diào)用,形如
function add(x, y) { return x + y } console.log(add(1, 2)) //函數(shù)調(diào)用 返回3
但是有一個apply()函數(shù),使我們擁有另一種方式來應(yīng)用函數(shù),例如
function add(x, y) { return x + y } console.log(add.apply(null, [1, 2])) //返回3
apply的第一個參數(shù)為null時,this指向全局對象(忘記請自行查閱查mdn),在上面這個例子里,通過apply來應(yīng)用函數(shù)的時候,效果和調(diào)用函數(shù)完全一致。
部分應(yīng)用從前文可知,函數(shù)調(diào)用就是讓一個參數(shù)集合(前面的[1,2])應(yīng)用到函數(shù)(前文的add函數(shù))中,那部分應(yīng)用就是考慮只傳遞部分參數(shù),而非所有參數(shù)。 還是上面add函數(shù)的例子,我們希望實(shí)現(xiàn)下面的形式(在下一節(jié)具體實(shí)現(xiàn)):
var newAdd = add.apply(null,[1])//部分應(yīng)用 只傳遞了第一個參數(shù) newAdd.apply(null,[2]) //3
分析上面的代碼可知,實(shí)現(xiàn)部分應(yīng)用的關(guān)鍵是:部分應(yīng)用的返回結(jié)果是一個新的函數(shù),該函數(shù)可以被傳入其他參數(shù)再次調(diào)用
柯里化(curry)現(xiàn)在進(jìn)入正題,前面講完了部分應(yīng)用。curry化的含義,就是使函數(shù)理解并處理部分應(yīng)用的過程
繼續(xù)按照上文的思路實(shí)現(xiàn)add函數(shù)的curry化:
function add(x, y) { // 如果只傳遞部分參數(shù),則部分應(yīng)用,返回一個新的函數(shù) if (y === undefined) { return function (y) { return x + y } } return x + y //如果傳遞所有參數(shù),直接完全應(yīng)用 } //運(yùn)行前一節(jié)代碼 var newAdd = add.apply(null, [1]) console.log(newAdd.apply(null, [2])) //3 console.log(newAdd.apply(null, [5])) //6
上述代碼已經(jīng)實(shí)現(xiàn)了前一節(jié)的要求,可以看到curry的結(jié)果就是:經(jīng)過一次curry的newadd函數(shù),變成一個與1求和的函數(shù),接應(yīng)用的時候只傳遞一個參數(shù),都能得到對應(yīng)的結(jié)果,同時也可以看出這個curry太局限。接下來我們就要考慮,如何實(shí)現(xiàn)通用的curry函數(shù)
通用curry函數(shù)先回憶前面的過程,來思考curry一個函數(shù)的實(shí)現(xiàn)步驟:
保存調(diào)用curry函數(shù)時傳入的參數(shù),返回一個新函數(shù)(即柯里化執(zhí)行結(jié)果)
結(jié)果函數(shù)在被調(diào)用后,要讓新的參數(shù)和舊的參數(shù)一起應(yīng)用的入?yún)⒑瘮?shù)中
注:入?yún)⒑瘮?shù)-要被curry的函數(shù),結(jié)果函數(shù)-被curry之后的函數(shù)*
文字比較抽象,可以直接看實(shí)現(xiàn)在回來看過程:
function commonCurry(fn) { var slice = Array.prototype.slice, storedArgs = slice.call(arguments, 1) //使用slice是為了把a(bǔ)rguments轉(zhuǎn)換成真正的數(shù)組,剝離此處第一個參數(shù),是因?yàn)榈谝粋€參數(shù)是fn return function () { var newArgs = slice.call(arguments), //新傳入的參數(shù) args = storedArgs.concat(newArgs) return fn.apply(null, args) } } //使用舉例 function add(a, b) { return a + b } var newAdd = commonCurry(add, 10) console.log(newAdd(5)) // 多個參數(shù) function add2(a, b, c, d) { return a + b + c + d } var newAdd2 = commonCurry(add2, 10, 10) console.log(newAdd2(5, 4))//29 // 多次curry var newAdd3 = commonCurry(newAdd2, 10) console.log(newAdd3(10))//40小結(jié)
之后會嘗試以更簡潔明了的方式來寫文章。如果內(nèi)容有錯誤的地方歡迎指出(覺得看著不理解不舒服想吐槽也完全沒問題);如果對你有幫助,歡迎點(diǎn)贊和收藏,轉(zhuǎn)載請征得同意后著明出處,如果有問題也歡迎私信交流,主頁添加了郵箱地址。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/96729.html
摘要:如果你對函數(shù)式編程有一定了解,函數(shù)柯里化是不可或缺的,利用函數(shù)柯里化,可以在開發(fā)中非常優(yōu)雅的處理復(fù)雜邏輯。同樣先看簡單版本的方法,以方法為例,代碼來自高級程序設(shè)計加強(qiáng)版實(shí)現(xiàn)上面函數(shù),可以換成任何其他函數(shù),經(jīng)過函數(shù)處理,都可以轉(zhuǎn)成柯里化函數(shù)。 我們經(jīng)常說在Javascript語言中,函數(shù)是一等公民,它們本質(zhì)上是十分簡單和過程化的。可以利用函數(shù),進(jìn)行一些簡單的數(shù)據(jù)處理,return 結(jié)果,...
摘要:作為函數(shù)式編程語言,帶來了很多語言上的有趣特性,比如柯里化和反柯里化。在一些函數(shù)式編程語言中,會定義一個特殊的占位變量。個人理解不知道對不對延遲執(zhí)行柯里化的另一個應(yīng)用場景是延遲執(zhí)行。不斷的柯里化,累積傳入的參數(shù),最后執(zhí)行。作為函數(shù)式編程語言,JS帶來了很多語言上的有趣特性,比如柯里化和反柯里化。 這里可以對照另外一篇介紹 JS 反柯里化 的文章一起看~ 1. 簡介 柯里化(Currying)...
摘要:里也有柯里化的實(shí)現(xiàn),只是平時沒有在意。如果函數(shù)柯里化后雖然生搬硬套,不過現(xiàn)實(shí)業(yè)務(wù)也會有類似場景。 柯里化 先解釋下什么是 柯里化 在計算機(jī)科學(xué)中,柯里化(英語:Currying),又譯為卡瑞化或加里化,是把接受多個參數(shù)的函數(shù)變換成接受一個單一參數(shù)(最初函數(shù)的第一個參數(shù))的函數(shù),并且返回接受余下的參數(shù)而且返回結(jié)果的新函數(shù)的技術(shù)。 js 里也有柯里化的實(shí)現(xiàn),只是平時沒有在意。先把原文簡介貼...
摘要:作為函數(shù)式編程語言,帶來了很多語言上的有趣特性,比如柯里化和反柯里化。個人理解不知道對不對延遲執(zhí)行柯里化的另一個應(yīng)用場景是延遲執(zhí)行。不斷的柯里化,累積傳入的參數(shù),最后執(zhí)行。 作為函數(shù)式編程語言,JS帶來了很多語言上的有趣特性,比如柯里化和反柯里化。 這里可以對照另外一篇介紹 JS 反柯里化 的文章一起看~ 1. 簡介 柯里化(Currying),又稱部分求值(Partial Evalu...
摘要:笑中自動柯里化的精巧實(shí)現(xiàn)柯里化是函數(shù)式編程中很重要的一環(huán),很多函數(shù)式語言都會默認(rèn)將函數(shù)自動柯里化。 什么是柯里化? 在計算機(jī)科學(xué)中,柯里化(Currying)是把接受多個參數(shù)的函數(shù)變換成接受一個單一參數(shù)(最初函數(shù)的第一個參數(shù))的函數(shù),并且返回接受余下的參數(shù)且返回結(jié)果的新函數(shù)的技術(shù)。這個技術(shù)由 Christopher Strachey 以邏輯學(xué)家 Haskell Curry 命名的,盡管...
摘要:一個經(jīng)常會看到的函數(shù)的實(shí)現(xiàn)為第一版我們可以這樣使用或者或者已經(jīng)有柯里化的感覺了,但是還沒有達(dá)到要求,不過我們可以把這個函數(shù)用作輔助函數(shù),幫助我們寫真正的函數(shù)。 JavaScript 專題系列第十三篇,講解函數(shù)柯里化以及如何實(shí)現(xiàn)一個 curry 函數(shù) 定義 維基百科中對柯里化 (Currying) 的定義為: In mathematics and computer science, cu...
閱讀 2791·2021-11-17 09:33
閱讀 4455·2021-09-22 15:57
閱讀 2866·2019-08-30 14:16
閱讀 3133·2019-08-29 14:07
閱讀 2413·2019-08-26 11:55
閱讀 3415·2019-08-23 17:07
閱讀 1725·2019-08-23 16:50
閱讀 2535·2019-08-23 16:08