欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JavaScript函数柯里化原理与用法分析

程序员文章站 2023-11-04 11:07:58
本文实例讲述了javascript函数柯里化原理与用法。分享给大家供大家参考,具体如下: 柯里化是这样的一个转换过程,把接受多个参数的函数变换成接受一个单一参数(译注:最...

本文实例讲述了javascript函数柯里化原理与用法。分享给大家供大家参考,具体如下:

柯里化是这样的一个转换过程,把接受多个参数的函数变换成接受一个单一参数(译注:最初函数的第一个参数)的函数,如果其他的参数是必要的,返回接受余下的参数且返回结果的新函数。

也就是说是固定部分参数,返回一个接受剩余参数的函数,也称为部分计算函数,目的是为了缩小适用范围,创建一个针对性更强的函数。

例如,我想创建一个做自我介绍的函数,每个人只要输入自己姓名、性别、年龄即可。但是当a使用这个函数时,每次调用,都必须输入一次自己姓名、性别,实际只是年龄改变了而已,为此a会为自己生成一个柯里化的自我介绍函数,其中姓名和性别是固定参数。

相关代码请查看github.

function curry(fn){
  var args = array.prototype.slice.call(arguments, 1);
  return function(){
    var innerargs = array.prototype.slice.call(arguments);
    var finalargs = args.concat(innerargs);
    return fn.apply(null, finalargs);
  };
}
function selfintroduction(name, gender, age){
  console.log('hi, i am ' + name + ', ' + age +' years old ' + '. i am a ' + gender + '.');
}
var curriedselfintroduction = curry(selfintroduction, 'a', 'man');
curriedselfintroduction('12');
curriedselfintroduction('13');
curriedselfintroduction('14');

执行以后结果。

JavaScript函数柯里化原理与用法分析

当然,我们也可以写一个绑定新作用域的柯里化函数。

function curry(fn, context){
  var args = array.prototype.slice.call(arguments, 2);
  return function(){
    var innerargs = array.prototype.slice.call(arguments);
    var finalargs = args.concat(innerargs);
    return fn.apply(context, finalargs);
  };
}

尽管柯里化函数已经很牛了,但是它也让你必须花费点小心思在你所定义函数的参数顺序上。函数柯里化允许和鼓励你分隔复杂功能变成更小更容易分析的部分。这些小的逻辑单元显然是更容易理解和测试的,然后你的应用就会变成干净而整洁的组合,由一些小单元组成的组合。所以如果你能恰当使用柯里化函数,会使得你的js代码更优雅。

注意:建议你看一看es6(es2015)中的proxy,这是另一种对函数进行预处理的方法。

更多关于javascript相关内容可查看本站专题:《javascript面向对象入门教程》、《javascript中json操作技巧总结》、《javascript切换特效与技巧总结》、《javascript查找算法技巧总结》、《javascript动画特效与技巧汇总》、《javascript错误与调试技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》及《javascript数学运算用法总结

希望本文所述对大家javascript程序设计有所帮助。