函数式编程理解入门

  • 函数式编程随着 react 的流行收到越来越多的关注
  • VUE3 也开始拥抱函数式编程
  • 函数式编程可以抛弃 this
  • 打包过程可以利用 tree-shaking 过滤无用的代码
  • 方便测试 方便并行处理
  • 有很多库使用函数式编程: loadsh underscore ramda

函数式编程的概念

函数式编程可以认为是一种编程规范之一,我们经常听说的编程范式还有面向对象编程/面向过程编程

面向对象编程的思维方式:把现实生活中的事物抽象成程序世界的类和对象,通过封装/继承和多态来演示事物事件的联系

函数式编程的思维方式:把现实生活中的事物和事物之间的联系抽象到程序的世界

  • 函数式编程的函数不是指程序中的的函数(方法),而是数学中的映射关系
  • 相同的输入要有相同的输出
  • 函数式编程用来表述数据之间的映射
// 非函数式
// 这是面向过程编程
let num1 = 2;
let num2 = 3;
let sum = num2 + num2;

// 函数式
function add(n1, n2) {
  return n1 + n2;
}
let sum = add(2, 3);

函数是一等公民

  • 函数可以存储在变量中
  • 函数可以作为参数
  • 函数可以作为返回值

高阶函数

  • 可以把函数作为参数传递
  • 函数可以作为返回值

闭包

从外部的作用域,我们可以访问一个函数内的函数,一个函数内容返回一个函数,并且返回的函数可以访问上一层函数的变量

本质:函数在执行的时候会放到一个执行栈中,当函数执行完毕后会从执行栈中移除,但是堆上的作用域成员因为被外部引用,所以不能被释放,因此内部函数依然可以访问外部函数的成员

柯里化

// 模拟函数柯里化原理

function curry(func) {
  return function curried(...args) {
    // 判断实参和形参的个数 如果参数大于或者等于,那个直接执行下面的返回函数把参数传进去
    // 否则进入判断,把参数合并再传入函数中,
    if (args.length < func.length) {
      return function () {
        return curried(...args.concat(Array.from(arguments)));
      };
    }
    return func(...args);
  };
}

function getSum(a, b, c) {
  return a + b + c;
}

const curried = curry(getSum);
console.log(curried(1, 2, 3));
console.log(curried(1)(2, 3));

总结

  • 柯里化可以让我们给函数传递较少的参数得到一个已经记住的某个固定参数的新函数
  • 这是一种对函数参数的缓存
  • 让函数变的更灵活,让函数的粒度更小
  • 可以把多元函数(指多个参数)转化成一元函数(指一个参数),可以组合使用函数,使其产生强大的功能

函数组合

  • 函数组合: 如果一个函数要经过多个函数才能得带最终值,这个时候可以把中间的过程函数合并成一个函数
  • 函数就像是数据的管道,函数组合就是把这些管道连接起来,让数据穿过多个管道形成最终的结果
  • 函数组合默认的是从右向左执行
let fn = compose(f1, f2, f3);
let b = fn(a);
// 执行顺序 f3 f2 f1
// 函数组合示例

function compose(f, g) {
  return function (value) {
    return f(g(value));
  };
}
function reverse(array) {
  return array.reverse();
}

function first(array) {
  return array[0];
}
const last = compose(first, reverse);
console.log(last([1, 2, 3, 4])); // 4
// 模拟loadsh组合函数

function compose(...args) {
  return function (value) {
    return args.reverse().reduce(function (acc, fn) {
      return fn(acc);
    }, value);
  };
}
// 精简版
const compose = (...args) => (value) =>
  args.reverse().reduce((acc, fn) => fn(acc), fn);

函数组合要满足结合律

let a = compose(f, g, h);
let v = compose(compose(f, g), h) == compose(f, compose(g, h));
// 意思是我们可以把f和组合,也可以g 和 h组合 效果都是一样的

函数组合怎么调式

const log = (v) => {
  console.log(v);
  return v;
};

function compose(f, g) {
  return function (value) {
    return f(g(value));
  };
}
function reverse(array) {
  return array.reverse();
}

function first(array) {
  return array[0];
}
// log
const last = compose(first, log, reverse);
console.log(last([1, 2, 3, 4])); // 4

point Free

一种编码风格

  • 不需要指明处理的数据
  • 只需要合成运算过程
  • 需要定义一些辅助的基本运算函数
// 代码示例
// world wild web ==> W.W.W
const fp = require("loadsh/fp");
const firstLetterToUpper = fp.flowRight(
  fp.join("."),
  fp.map(fp.first),
  fp.map(fp.toUpper),
  fp.split("")
);
console.log(firstLetterToUpper("world wild web"));

函子

函子的作用就是:如何把函数的副作用控制在可控范围内、异常处理、异步操作等
函子相关文章 推荐阅读 https://www.jianshu.com/p/afbce25c18fb

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,258评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,335评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,225评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,126评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,140评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,098评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,018评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,857评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,298评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,518评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,400评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,993评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,638评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,661评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352