什么是纯函数?

纯函数的概念:一个函数的返回结果只依赖其参数,并且执行过程中没有副作用。

下面我们来分别说明一下概念中的两个条件。

返回结果只依赖其参数

返回值只和函数参数有关,与外部无关。无论外部发生什么样的变化,函数的返回值都不会改变。

//  非纯函数 返回值与a相关,无法预料
const a = 1
const foo = (b) => a + b
foo(2)                    // => 3

// 纯函数 返回结果只依赖于它的参数 x 和 b,foo(1, 2) 永远是 3。今天是 3,明天也是 3,在服务器跑是 3,在客户端跑也 3,不管你外部发生了什么变化,foo(1, 2) 永远是 3。只要 foo 代码不改变,你传入的参数是确定的,那么 foo(1, 2) 的值永远是可预料的。
const a = 1
const foo = (x, b) => x + b
foo(1, 2) // => 3
函数执行过程中没有副作用

函数执行的过程中对外部产生了可观察的变化,我们就说函数产生了副作用。
例如修改外部的变量、调用DOM API修改页面,发送Ajax请求、调用window.reload刷新浏览器甚至是console.log打印数据,都是副作用。
例如:

 // 无副作用
const a = 1
const foo = (obj, b) => {
  return obj.x + b
}
const counter = { x: 1 }
foo(counter, 2)                       // => 3
counter.x                             // => 1

// 修改一下 ,再观察(修改了外部变量,产生了副作用。)
const a = 1
const foo = (obj, b) => {
  obj.x = 2;
  return obj.x + b
}
const counter = { x: 1 }
foo(counter, 2)                       // => 4
counter.x                             // => 2

当然,如果实在函数内部创建的变量。进行修改则不会产生副作用。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值