摘要:題目發(fā)現(xiàn)一道有意思的面試題如何實現(xiàn)首先簡單分析一下,我們就能發(fā)現(xiàn)這是一個函數(shù)傳值次得到。簡單實現(xiàn)利用閉包,執(zhí)行函數(shù)時一個匿名函數(shù),用于最終返回結(jié)果。當(dāng)然,這個方法有個明顯缺陷,就是如果函數(shù)變成,我們就又要手動嵌套一層。
題目
發(fā)現(xiàn)一道有意思的面試題:如何實現(xiàn) add(1)(2)(3)=6 ?
首先簡單分析一下,我們就能發(fā)現(xiàn)這是一個函數(shù)傳值 return3次得到6 。
簡單實現(xiàn)function add(a) { return function (b) { return function (c) { return a + b + c; } } }
利用閉包,執(zhí)行add函數(shù)時return一個匿名函數(shù),用于最終返回結(jié)果。
當(dāng)然,這個方法有個明顯缺陷,就是如果函數(shù)變成 add(1)(2)(3)(4) ,我們就又要手動嵌套一層。
分析有沒有什么辦法呢? 有!
我們先把這個問題簡化一下:
如何實現(xiàn)函數(shù)對自身的調(diào)用呢,如: add()()() ?
function add () { // 方法1:利用apply return function () { return add.apply(); } // 方法2: // return add; }
那么,問題就可以這么實現(xiàn):
function add () { var args = Array.prototype.slice.call(arguments); console.log(args); var fn = function () { var fn_args = Array.prototype.slice.call(arguments); return add.apply(null, args.concat(fn_args)); }; return fn; }
至此, add 函數(shù)的多層嵌套以及所有參數(shù),我們都拿到了,下面只需要把參數(shù)相加就可以了。
但我們不能直接相加,因為我們 add 函數(shù) return add.apply() 返回的是函數(shù), 因此即使相加,值我們也是拿不到的。
valueOf這里我們要用到 valueOf 方法。
valueOf 方法返回指定對象的原始值。
function add () { var args = Array.prototype.slice.call(arguments); var fn = function () { var fn_args = Array.prototype.slice.call(arguments); return add.apply(null, args.concat(fn_args)); }; fn.valueOf = function () { return args.reduce(function (a, b) { return a + b; }); }; return fn; }
搞定!現(xiàn)在這個方法不僅支持 add(1)(2)(3) 而且支持 add(1,2,3) 。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/99833.html
摘要:忍者秘籍一書中,對于柯里化的定義如下在一個函數(shù)中首先填充幾個參數(shù)然后再返回一個新函數(shù)的技術(shù)稱為柯里化。回到我們的題目本身,其實根據(jù)測試用例我們可以發(fā)現(xiàn),函數(shù)的要求就是接受單一函數(shù),例如但是與柯里化不同之處在于,柯里化返回的一個新函數(shù)。 歡迎大家再一次來到我的文章專欄:從面試題中我們能學(xué)到什么,各位同行小伙伴是否已經(jīng)開始了悠閑的春節(jié)假期呢?在這里提前祝大家雞年大吉吧~哈哈,之前有人說...
摘要:原題如下寫一個方法,當(dāng)使用下面的語法調(diào)用時,能正常工作這道題要考察的,就是對函數(shù)柯里化的理解。當(dāng)參數(shù)只有一個的時候,進(jìn)行柯里化的處理。這其實就是函數(shù)柯里化的簡單應(yīng)用。 showImg(https://segmentfault.com/img/bVbopGm?w=620&h=350); 前言 這是前端面試題系列的第 6 篇,你可能錯過了前面的篇章,可以在這里找到: ES6 中箭頭函數(shù)的...
摘要:函數(shù)柯里化在函數(shù)式編程中,函數(shù)是一等公民。函數(shù)柯里化的主要作用和特點就是參數(shù)復(fù)用提前返回和延遲執(zhí)行。可能在實際應(yīng)用場景中,很少使用函數(shù)柯里化的解決方案,但是了解認(rèn)識函數(shù)柯里化對自身的提升還是有幫助的。 最近在整理面試資源的時候,發(fā)現(xiàn)一道有意思的題目,所以就記錄下來。 題目 如何實現(xiàn) multi(2)(3)(4)=24? 首先來分析下這道題,實現(xiàn)一個 multi 函數(shù)并依次傳入?yún)?shù)執(zhí)行,...
摘要:如果你對函數(shù)式編程有一定了解,函數(shù)柯里化是不可或缺的,利用函數(shù)柯里化,可以在開發(fā)中非常優(yōu)雅的處理復(fù)雜邏輯。同樣先看簡單版本的方法,以方法為例,代碼來自高級程序設(shè)計加強版實現(xiàn)上面函數(shù),可以換成任何其他函數(shù),經(jīng)過函數(shù)處理,都可以轉(zhuǎn)成柯里化函數(shù)。 我們經(jīng)常說在Javascript語言中,函數(shù)是一等公民,它們本質(zhì)上是十分簡單和過程化的。可以利用函數(shù),進(jìn)行一些簡單的數(shù)據(jù)處理,return 結(jié)果,...
閱讀 3724·2021-10-13 09:39
閱讀 3789·2021-09-24 09:48
閱讀 1189·2021-09-01 10:30
閱讀 2526·2019-08-30 15:55
閱讀 1774·2019-08-29 16:39
閱讀 2296·2019-08-26 13:55
閱讀 3050·2019-08-26 12:23
閱讀 1634·2019-08-26 11:59