浅聊偏函数

更新日期: 2022-06-02阅读: 1.5k标签: 函数

什么是偏函数

首先我们知道,这是一个函数:

function ajax(url, data, callback) {
  // ..
}

这是另外一个函数:

function ajaxTest1(data, callback) {
  ajax('http://www.test.com/test1', data, callback);
}

ajaxTest1 函数相比 ajax 函数,少传了一个参数,它的 url 被固定到了 ajaxTest1 的函数体内;

同理,我们还可以写出 ajaxTest2、ajaxTest3、……、ajaxTestN

如果我们直接写:

function ajaxTest2(data, callback) {
  ajax('http://www.test.com/test2', data, callback);
}

function ajaxTest3(data, callback) {
  ajax('http://www.test.com/test3', data, callback);
}

......

function ajaxTestN(data, callback) {
  ajax('http://www.test.com/testN', data, callback);
}


这样有问题吗?

从“能用就行”的角度看,是可以的;如果是从“设计模式”的角度看,就不太 ok 了!

因为这样写,都没有复用到 ajax 函数呀 

基于这种背景,偏函数应用应用而生!

它做了什么?—— 用一个函数封装 ajax 函数,使得封装后的函数 能够先绑定部分参数, 这个封装后的函数就是偏函数;

比方说:

let ajaxTest2 = partial(ajax,'http://www.test.com/test2')

我们用 partial 函数封装了 ajax 函数,然后先绑定了 url 为 'www.test.com/test2' ,封装后的 ajaxTest2 就是偏函数,是函数 ajax 的偏函数;

调用方式不变:

ajaxTest2(data,callback)

这样做的好处就是,我们复用了 ajax,并且封装后的偏函数,需要的传参更少了,这一点十分关键;老观众都知道:在函数式编程中我们提倡:函数的输入和输出,都尽量保持只有 1 个是最佳的。

那么,现在的问题就来了,partial 这个用于封装的函数怎么实现的呢??

和前面提到过的柯里化很像,partial 的目的就是收集参数,然后传给回调函数,它是这样的:

function partial(fn, ...presetArgs) { // presetArgs 是需要先被绑定下来的参数
  return function partiallyApplied(...laterArgs) { //  ...laterArgs 是后续参数
        let allArgs =presetArgs.concat(laterArgs) // 收集到一起
        return fn.apply(this, allArgs) // 传给回调函数 fn
  }
}

这就是基础的偏函数理解。

实际上,针对不同的削减参数的需求,偏函数有不同的写法;但是原理是不变的:对原始函数二次封装,固定部分参数,返回回调函数,只需要传入更少的参数~~

作者:掘金安东尼
链接:https://juejin.cn/post/7104409137110335502

链接: https://fly63.com/article/detial/11642

JavaScript 函数式编程

我理解的 JavaScript 函数式编程,都认为属于函数式编程的范畴,只要他们是以函数作为主要载体的。

Js函数式编程,给你的代码增加一点点函数式编程的特性

给你的代码增加一点点函数式编程的特性,最近我对函数式编程非常感兴趣。这个概念让我着迷:应用数学来增强抽象性和强制纯粹性,以避免副作用,并实现代码的良好可复用性。同时,函数式编程非常复杂。

让我们来创建一个JavaScript Wait函数

Async/await以及它底层promises的应用正在猛烈地冲击着JS的世界。在大多数客户端和JS服务端平台的支持下,回调编程已经成为过去的事情。当然,基于回调的编程很丑陋的。

JavaScript函数创建的细节

如果你曾经了解或编写过JavaScript,你可能已经注意到定义函数的方法有两种。即便是对编程语言有更多经验的人也很难理解这些差异。在这篇博客的第一部分,我们将深入探讨函数声明和函数表达式之间的差异。

编写小而美函数的艺术

随着软件应用的复杂度不断上升,为了确保应用稳定且易拓展,代码质量就变的越来越重要。不幸的是,包括我在内的几乎每个开发者在职业生涯中都会面对质量很差的代码。这些代码通常有以下特征:

javascript回调函数的理解和使用方法(callback)

在js开发中,程序代码是从上而下一条线执行的,但有时候我们需要等待一个操作结束后,再进行下一步操作,这个时候就需要用到回调函数。 在js中,函数也是对象,确切地说:函数是用Function()构造函数创建的Function对象。

js调用函数的几种方法_ES5/ES6的函数调用方式

这篇文章主要介绍ES5中函数的4种调用,在ES5中函数内容的this指向和调用方法有关。以及ES6中函数的调用,使用箭头函数,其中箭头函数的this是和定义时有关和调用无关。

JavaScript中函数的三种定义方法

函数的三种定义方法分别是:函数定义语句、函数直接量表达式和Function()构造函数的方法,下面依次介绍这几种方法具体怎么实现,在实际编程中,Function()构造函数很少用到,前两中定义方法使用比较普遍。

js在excel的编写_excel支持使用JavaScript自定义函数编写

微软 称excel就实现面向开发者的功能,也就是说我们不仅可以全新定义的公式,还可以重新定义excel的内置函数,现在Excel自定义函数增加了使用 JavaScript 编写的支持,下面就简单介绍下如何使用js来编写excel自定义函数。

js中的立即执行函数的写法,立即执行函数作用是什么?

这篇文章主要讲解:js立即执行函数是什么?js使用立即执行函数有什么作用呢?js立即执行函数的写法有哪些?

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!