加油,今天周二啦!😍
文章目录
- 前言
- 一、js 的纯函数
- 二、副作用
- 三、纯函数的优势
- 四、JavaScript 柯里化
- 五、柯里化作用 - 让函数的职责单一
- 六、柯里化作用 - 逻辑的复用
- 七、自动柯里化函数(我没理解,等我理解了再更)
前言
提示:这里可以添加本文要记录的大概内容:
例如:随着人工智能的不断发展,机器学习这门技术也越来越重要,很多人都开启了学习机器学习,本文就介绍了机器学习的基础内容。
一、js 的纯函数
- 函数式编程中有一个非常重要的概念叫纯函数,JavaScript 符合
函数式编程的范式
,所以也有纯函数
的概念 - 在react开发中纯函数是被多次提及的,比如react中组件就被要求像是一个纯函数(为什么是像,因为还有class组件),redux中有一个reducer的概念,也是要求必须是一个纯函数;所以掌握纯函数对于理解很多框架的设计是非常有帮助的;
纯函数的维基百科定义:
- 在程序设计中,若一个函数符合以下条件,那么这个函数被称为纯函数:
- 此函数在相同的输入值时,
需产生相同的输出
。 - 函数的
输出和输入值以外的其他隐藏信息或状态无关
,也和由I/O设备产生的外部输出无关
。 - 该函数
不能有语义上可观察的函数副作用
,诸如“触发事件”
,使输出设备输出,或更改输出值以外物件的内容
等。
当然上面的定义会过于的晦涩,所以我简单总结一下:
- 确定的输入,一定会产生确定的输出;
- 函数在执行过程中,不能产生副作用;
比如:
- 数组方法:slice 和 splice
- 在调用 slice 时,不会修改原始数据(输入数据)
- 在调用 splice 时,会修改
二、副作用
纯函数在执行的过程中就是不能产生这样的副作用,
副作用往往是产生bug的 “温床”
- 副作用(side effect)其实本身是医学的一个概念,比如我们经常说吃什么药本来是为了治病,可能会产生一些其他的副作用;
- 在计算机科学中,也引用了副作用的概念,表示 在执行一个函数 时,除了 返回函数值之外 ,还对调用函数产生了附加的影响,比如修改了全局变量,修改参数或者改变外部的存储;
三、纯函数的优势
- 因为可以
安心的编写
和安心的使用
:
- 在写的时候保证了函数的纯度,只是单纯实现自己的业务逻辑即可,不需要关心传入的内容是如何获得的或
者依赖其他的外部变量是否已经发生了修改; - 在用的时候,确定你的输入内容不会被任意篡改,并且自己确定的输入,一定会有确定的输出;
- React中就要求我们无论是函数还是class声明一个组件,这个组件都必须像纯函数一样,保护它们的props不被修改
四、JavaScript 柯里化
柯里化也是属于函数式编程里面一个非常重要的概念。
我们先来看一下维基百科的解释:
把接收多个参数的函数,变成接受一个单一参数(最初函数的第一个参数)的函数
,并且返回接受余下的参数
,而且返回结果的新函数的技术
;- 柯里化声称 “如果你固定某些参数,你将得到接受余下参数的一个函数”;
维基百科的结束非常的抽象,我们这里做一个总结:
- 只传递给函数一部分参数来调用它,让它返回一个函数去处理剩余的参数;
这个过程就称之为柯里化
;
图一是柯里化,图二是简化
五、柯里化作用 - 让函数的职责单一
在函数式编程中,我们其实往往希望一个函数处理的问题尽可能的 单一
,而不是将一大堆的处理过程交给一个函数来处理;那么我们是否就可以将每次传入的参数在单一的函数中进行处理,处理完后在下一个函数中再使用处理后的结果;
比如下面的案例我们进行一个修改:
传入的函数需要分别被进行如下处理
- 第一个参数 + 2
- 第二个参数 * 2
- 第三个参数 ** 2
其实也就相当于
function add2(x,y,z){x=x+2y=y*2z=z*zreturn x+y+z}
但如果,在处理x,y, z 各有十行代码时??
柯里化就会让功能清晰
六、柯里化作用 - 逻辑的复用
柯里化还有一大好处就是逻辑的复用,比如以下案例,我想找男朋友,得满足4个条件,当我其中一些要求固定时,可以 定制化
,进而实现逻辑的复用
function boy(time){...return function (work){...return function (habbi){...return function (type){...}}}}boy('19岁')('前端')('健身')('狼狗')var boy_time=boy('19岁')boy_time('前端')('健身')('狼狗')var boy_B=boy('19岁')('前端')boy_B('跑步')('奶狗')var boy_c=boy('29岁')('后端')('写字')boy_c('奶狗')
七、自动柯里化函数(我没理解,等我理解了再更)
以上的案例里我都是手动写的函数,