美文网首页
JavaScript函数式编程

JavaScript函数式编程

作者: iOS小洁 | 来源:发表于2023-03-06 20:46 被阅读0次

JavaScript函数arguments

arguments 是一个 对应于 传递给函数的参数 的 类数组(array-like)对象。

array-like意味着它不是一个数组类型,而是一个对象类型:

  • 拥有数组的一些特性,比如说length,比如可以通过index索引来访问;
  • 没有数组的一些方法,比如forEach、map等;

arguments转数组

  // 1.自己遍历
  var newArr = []
  for (var i = 0; i < arguments.length; i++) {
    newArr.push(arguments[i] * 10)
  }
  console.log(newArr)
  
  //Array.prototype.slice将arguments转成array
  var newArr2 = Array.prototype.slice.call(arguments)
  console.log(newArr2)
  var newArr3 = [].slice.call(arguments)
  console.log(newArr3)
  
  // 2.3.ES6的语法
  var newArr4 = Array.from(arguments)
  console.log(newArr4)
  var newArr5 = [...arguments]
  console.log(newArr5)

箭头函数不绑定arguments

箭头函数是不绑定arguments的,所以我们在箭头函数中使用arguments会去上层作用域查找

// 1.案例一:
var foo = () => {
  console.log(arguments) // 找不到,报错
}
foo()

// 2.案例二:
function foo() {
  var bar = () => {
    console.log(arguments) // [123 ...]
  }
  return bar
}
var fn = foo(123)
fn()

JavaScript纯函数

纯函数的定义: 确定的输入,一定会产生确定的输出; 函数在执行过程中,不能产生副作用;

副作用: 表示在执行一个函数时,除了返回函数值之外,还对调用函数产生 了附加的影响,比如修改了全局变量,修改参数或者改变外部的存储;

纯函数的案例

slice:slice截取数组时不会对原数组进行任何操作,而是生成一个新的数组;slice就是一个纯函数,不会修改传入的参数;

splice:splice截取数组, 会返回一个新的数组, 也会对原数组进行修改; 非纯函数

纯函数优势

只是单纯实现自己的业务逻辑即可,不需要关心传入的内容是如何获得的或者依赖其他的外部变量是否已经发生了修改;

你在用的时候,你确定你的输入内容不会被任意篡改,并且自己确定的输入,一定会有确定的输出;

实例:React中就要求我们无论是函数还是class声明一个组件,这个组件都必须像纯函数一样,保护它们的props不被修改

JavaScript柯里化

柯里化:只传递给函数一部分参数来调用它,让它返回一个函数去处理剩余的参数;

function add(x, y, z) {
  return x + y + z
}

var result = add(10, 20, 30)
console.log(result)

function sum1(x) {
  return function(y) {
    return function(z) {
      return x + y + z
    }
  }
}

var result1 = sum1(10)(20)(30)
console.log(result1)

柯里化简化代码

// 简化柯里化的代码
var sum2 = x => y => z => {
  return x + y + z
}

console.log(sum2(10)(20)(30))

var sum3 = x => y => z => x + y + z
console.log(sum3(10)(20)(30))

柯里化意义:希望一个函数处理的问题尽可能的单一,而不是将一大堆的处理过程交给一个 函数来处理;

组合函数

组合函数:依次执行的两个函数,每次都需要进行两个函数的调用,可将其组合起来,自动依次调用

function hyCompose(...fns) {
  var length = fns.length
  for (var i = 0; i < length; i++) {
    if (typeof fns[i] !== 'function') {
      throw new TypeError("Expected arguments are functions")
    }
  }

  function compose(...args) {
    var index = 0
    var result = length ? fns[index].apply(this, args): args
    while(++index < length) {
      result = fns[index].call(this, result)
    }
    return result
  }
  return compose
}

相关文章

  • JavaScript函数式编程

    读完《JavaScript函数式编程》《JavaScript函数式编程指南》这两本书,对JavaScript函数式...

  • JavaScript函数式编程

    读完《JavaScript函数式编程》《JavaScript函数式编程指南》这两本书,对JavaScript函数式...

  • part1整理

    函数式编程:JavaScript函数式编程指南 异步编程:异步编程 Promise源码 JavaScript基础知...

  • 5.纯函数

    理解JavaScript纯函数 函数式编程中有一个非常重要的概念叫纯函数,JavaScript符合函数式编程的范式...

  • javascript函数式编程

    参考书籍:《javascript 函数式编程》 什么是函数式编程? 函数式编程通过函数将值转换为抽象单元,接着用于...

  • 【JavaScript】技术参考资料

    JS基础、高级、进阶 MDN·JavaScript 函数式编程 阮一峰老师的入门简介: 函数式编程初探、函数式编程...

  • javascript 函数式编程

    1.函数式编程是什么 为什么要函数式编程 我眼中的 JavaScript 函数式编程 2.什么是函数组合 征服 J...

  • 深入理解JavaScript函数式编程

    JavaScript函数式编程 大家都知道JavaScript可以作为面向对象或者函数式编程语言来使用,一般情况下...

  • JavaScript面试:什么是函数组合?

    函数式编程正在占领JavaScript世界。就在几年前,很少有JavaScript程序员甚至不知道什么是函数式编程...

  • Node.js学习(8.5)

    Node.js安装配置 指令式编程思维 顺序 选择 循环 函数式编程思维 函数 抽象化函数 JavaScript语...

网友评论

      本文标题:JavaScript函数式编程

      本文链接:https://www.haomeiwen.com/subject/kftvldtx.html