柯理化与反柯理化

<script>
function sum(a,b,c,d,e){
return a+b+c+d+e
}
const currying = (fn,arg = [])=>(...args)=>(
fn.length === args.concat(arg).length?fn(...args.concat(arg))
:currying(fn,[...args,...arg])
)

const fn = currying(sum)
console.log(fn(1,2)(3)(4)(5))
const fn1 = fn(1)
const fn2 = fn1(2)
console.log(fn2(3,4)(5))
</script>
 
 
<script>
Function.prototype.uncurring = function(){
let self = this
return function (){
let obj = Array.prototype.shift.call(arguments)
return self.apply(obj,arguments)
}
}
let push = Array.prototype.push.uncurring()
let cu = {}
push(cu,"sex","shuai")
console.log(cu)

</script>
posted @   国服第一李师师  阅读(42)  评论(0编辑  收藏  举报
编辑推荐:
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
· 用 C# 插值字符串处理器写一个 sscanf
· Java 中堆内存和栈内存上的数据分布和特点
· 开发中对象命名的一点思考
阅读排行:
· PPT革命!DeepSeek+Kimi=N小时工作5分钟完成?
· What?废柴, 还在本地部署DeepSeek吗?Are you kidding?
· DeepSeek企业级部署实战指南:从服务器选型到Dify私有化落地
· 程序员转型AI:行业分析
· 重磅发布!DeepSeek 微调秘籍揭秘,一键解锁升级版全家桶,AI 玩家必备神器!
点击右上角即可分享
微信分享提示