av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

JavaScript函數柯里化實現原理及過程

瀏覽:122日期:2023-10-07 08:11:06

簡介當我們在讀Vue源碼到時候會發現,在它的 _update 實例中就用到了函數柯里化,(createPatchFunction方法)有興趣的可以

去看一下。

柯里化(Currying)是把接受多個參數的函數變換成接受一個單一參數(最初函數的第一個參數)的函數,并且返回接受余下的參數而且返回結果的新函數的技術。

在《Mostly adequate guide》中,這樣總結了 Currying ——只傳遞給函數一部分參數來調用它,讓它返回一個函數去處理剩下的參數。

Currying 是函數式編程的一種實現,可以給我們的編程帶來便利。那 Currying 函數到底長什么樣呢?請往下看,我們根據它的概念自己來寫一個柯里化函數

實現

// 如何實現 add(1,2) === add(1)(2)let add = (...args) => { return args.length === 1 ? a => a + args[0] : args[0] + args[1]}

這個似乎有一點接近柯里化的意思,但并不是真正的Currying,我們應該做到 add(1,2,3,,,) === currying(add)(1,2,3,,,) 才能算是真正的柯里化函數,OK,我們繼續往下來,

let add = (...args) => args.reduce((a,b)=>a+b) let currying = (fn)=>{ return function(...args){ return fn.apply(this, args) }}// add(1,2,3,,,) === currying(add)(1,2,3,,,)

還有人這么玩,可以參考下

let currying = (fn) => { var args = [].slice.call(arguments, 1) return function() { var newArgs = args.concat([].slice.call(arguments)) return fn.apply(this, newArgs) }} let addCurry = currying(add, 1, 2);addCurry() // 3 addCurry = currying(add, 1);addCurry(2) // 3 addCurry = currying(add);addCurry(1, 2) // 3

實際上這個實現方法利用閉包的原理,有時間給大家做個對比,

分析

可以看到,實際上柯里化函數并不算難,要想實際運用在我們的開發中,需要我們花點小心思~

參考:https://github.com/FIGHTING-TOP/FE-knowlodge-base/issues/4

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 中文av在线播放 | 亚洲视频免费在线观看 | 91欧美| 色啪网| 亚洲一区二区不卡在线观看 | 欧美精品三区 | 国产成人综合网 | 欧美一二三区 | 久久国产精品一区二区 | 亚洲电影第三页 | 精品免费视频 | 国产在线精品一区二区 | 亚洲精品视频播放 | www.亚洲成人网 | 免费一二区 | 日韩欧美国产精品综合嫩v 一区中文字幕 | 亚洲一区欧美 | 免费一区在线观看 | 国产在线视频网 | 精品久久久久国产 | 国产美女免费视频 | 九九免费观看视频 | 国产精品毛片一区二区三区 | 久久亚洲一区二区三区四区 | 亚洲人成人一区二区在线观看 | 一区二区av| 日韩免费一区二区 | 欧美午夜精品 | 国产成人高清 | www.99热.com | 国产一区精品 | 欧美日高清 | 精品国产18久久久久久二百 | 成人在线播放网址 | 在线播放国产一区二区三区 | 在线免费视频一区 | 国产精品99一区二区 | 欧美成人一级视频 | 久久国产一区二区三区 | 日韩中文字幕第一页 | 2022精品国偷自产免费观看 |