扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
从FP函数式编程的眼中看来,世界的万事万物就是处理数据流:

创新互联是网站建设技术企业,为成都企业提供专业的网站建设、成都网站制作,网站设计,网站制作,网站改版等技术服务。拥有十多年丰富建站经验和众多成功案例,为您定制适合企业的网站。十多年品质,值得信赖!
- input --> process -- output
FP函数式编程是一种思维方式:
比如非函数式,会这样写程序:
- > var name = "gaowei";
- > var greeting = "Hello,I'm ";;
- > console.log(greeting + name)
- Hello,I'm gaowei
而函数范式编程则会这样写程序:
- > function greet(name) {
- ... return "Hi, I'm " + name;
- ... }
- > greet("Gaowei");
- "Hi, I'm Gaowei"
举例说明“非纯函数”,
- > let name = "Gaowei";
- > function greet() {
- ... console.log("Hi, I'm " + name);
- ... }
- > greet()
- Hi, I'm gaowei
这就不是一个纯函数,因为没有返回结果。
而纯函数则是:
- > function greet(name) {
- ... return "Hi, I'm " + name;
- ... }
在高阶函数中,函数本身又可作为输入与输出。
- > function setAdjectifier(adjective) {
- ... return function(description) {
- ..... return adjective + " " + description;
- ..... }
- ... }
- > let greatifier = setAdjectifier("great");
- > greatifier("meeting")
- 'great meeting'
map与filter之间的关联与区别,可以参见下面这张图:
举例,我们惯常的做法常常为:
- > let fruits = ['apple', 'banana', 'peach'];
- > fruits[2] = 'orange'
- 'orange'
- > fruits
- [ 'apple', 'banana', 'orange' ]
上面的mutation的处理方法,将会修改原始数据。
尝试 functional-programming的方式为:
- > newFruits = fruits.map( rm => rm == "orange" ? "peach" : rm)
- [ 'apple', 'banana', 'peach' ]
- > fruits
- [ 'apple', 'banana', 'orange' ]
而能够高效处理 immutable 数据的常用库为:Mori, immutable.js, Underscor, Lodash, Ramda 等。

我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流