js高阶函数以及函数柯里化

高阶函数的概念:

高阶函数的概念:

  • 一个函数返回一个函数
  • 一个函数可以参数接受一个函数
    这两个条件满足任意一个均可 ,promise内部肯定也是回调函数 (内部包含这高阶函数)。

应用:

  • 扩展函数
// 扩展方法 会用到高阶函数 
function core(...args){
  // 剩余运算符
  // .... 前面增加的逻辑
  console.log('core',args)
  // .. 之后增加的逻辑
}

// 给core函数增加一些额外的逻辑 但是不能更改核心代码
Function.prototype.before = function(cb){
  return (...args)=>{
    // newCore 剩余运算符 可以把多个参数转化成数组
    cb();
    this(...args) // 扩展运算符
  }
}

let newCore = core.before(()=>{
  console.log('before')
})
newCore('a','b')

函数柯里化的概念

  • 函数柯里化:多个参数的传入,把他转化成 n个函数,可以暂存变量(主要用于缓存,将参数缓存到代码中,在返回一个新的函数直到参数都传递完成后调用最后的函数)
  • 一般柯里化参数的要求都是一个个的传 ==》多个参数传入就是偏函数
    实现通用的函数柯里化
function curring(fn){
  const inner = (args=[])=>{
    return args.length >= fn.length ? fn(...args) : (...userArgs)=> inner([...args,...userArgs])
  }
  return inner()
}```


版权声明:本文为hahaqixu原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。