谈JavaScript中纯函数与非纯函数

简介: 纯函数是函数式编程的基础,之前在优雅编码的文章中提到过,多写纯函数,本文来简单介绍一下纯函数和非纯函数的概念和区别。

纯函数是函数式编程的基础,之前在优雅编码的文章中提到过,多写纯函数,本文来简单介绍一下纯函数和非纯函数的概念和区别。

纯函数与非纯函数

纯函数:

当给定相同的输入时,纯函数总是返回一致的输出,并且永远不会产生超出函数范围的效果,使它们可以预测。纯函数不管执行多少次,结果都是可预测的。

  • 可预测的
  • 没有副作用

非纯函数

当给定相同的输入时,不纯函数可能不会返回一致的结果,并且它们可能会产生超出函数范围的影响。

  • 不可预测的
  • 有副作用

可预测的

看看下面的例子:

const add = (a, b) => a + b;
console.log(add(2, 5));

对于当 a=2,b=3 的时候,函数 add 的结果可以预测到是 7 ,因此上面的函数可以说是纯函数。

接下来看下面的代码:

const add = (a, b) => a + b + parseInt(Math.random() * 10, 10);
console.log(add(2, 5));

现在这个函数已经不可预测了,因为增加了随机数。

副作用

还是从代码开始,你能预测输出吗?

const globalVar = 1;
const add = (a, b) => a + b + globalVar;
console.log(add(2, 5));

从当前来看,结果是可以预测的,为 8 ,看似是对的。

let globalVar = 1;
const add = (a, b) => a + b + globalVar;
globalVar = 0;
console.log(add(2, 5));

输出为 7 ,看似也能预测,但受 globalVar 的影响,这种现象就称为副作用。

前端开发中,其它有副作用的对象:

  1. Dom 操作:函数中存在 Dom 操作,因为 Dom 对象可以在很多地方修改。
const add = (a, b) => {
    document.write("hello");
    return a + b;
};
  1. 外部依赖:函数依赖于函数作用域之外的脚本库。
let globalVar = 1;
const add = (a, b) => a + b + globalVar;
  1. console:因为 console 是外部 API 而不是 JavaScript 方法。
const add = (a, b) => {
    console.log(a + b);
};
  1. fetchpromise、 和任何形式的异步函数都是不纯的,因为 JavaScript 本质上是同步的。

纯函数优点

通过上面介绍纯函数和非纯函数的概念的特征,现在来看下为什么要尽量多写纯函数:

  • 更容易进行测试,结果只依赖输入,测试时可以确保输出稳定
  • 更容易维护和重构,可以写出质量更高的代码
  • 更容易调用,不用担心函数会有什么副作用
  • 结果可以缓存,因为相同的输入总是会得到相同的输出


相关文章
|
10天前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
20 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
9天前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
23天前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
25天前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
2月前
|
JavaScript 前端开发 安全
JavaScript函数详解
JavaScript函数的详细解析,包括函数的定义和调用方式(如一般格式、匿名函数、构造函数、自调用函数、箭头函数和严格模式)、函数参数(arguments对象、可变参数、默认参数值)、闭包的概念和应用实例。
JavaScript函数详解
|
1月前
|
JavaScript 前端开发
js教程——函数
js教程——函数
31 4
|
1月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
16 2
|
1月前
|
JavaScript 前端开发 Java
【javaScript数组,函数】的基础知识点
【javaScript数组,函数】的基础知识点
23 5
|
1月前
|
JavaScript 前端开发
Node.js 函数
10月更文挑战第5天
21 3
|
1月前
|
前端开发 JavaScript
探索JavaScript函数基础
探索JavaScript函数基础
18 3