函数是javascript中非常重要的一部分,用途也非常的多,可作为参数、返回值、回调等等,下面有一些函数式编程的重要概念和定义

纯函数

纯函数属于程序设计的名词,其它语言中也是存在的,而在javascript中,符合以下规则即为纯函数。

  • 函数有相同的输入,必定有相同的输出
  • 函数的输出仅与输入有关,与其他隐藏信息无关
  • 不得产生任何的副作用,如 触发事件等

副作用:除了返回函数值以外,还对调用函数产生了其他的影响,如修改全局变量、修改参数或者改变外部存储。

以下几个示例来区分一下纯函数和非纯函数

1、数组方法

var arr1 = [1, 2, 3, 4]
var arr2 = [10, 20, 30, 40] const newArr1 = arr1.splice(1, 3)
const newArr2 = arr2.slice(1, 3) console.log(arr1, newArr1) // [1] [2, 3, 4]
console.log(arr2, newArr2) // [10, 20, 30, 40] [20, 30]

splice 通过下标值和长度操作原数组本身,修改了入参,所以不是纯函数。

slice 通过下标值截取数组,返回一个新的数组,没有副作用,是纯函数。

2、修改入参

var obj = { name: 'alice' }
function foo(info) {
  info.name = 'kiki'
  return info
}
foo(obj) function bar(info) {
  return {
    ...info,
    name: 'kiki'
  }
}
bar(obj)

上面两个函数的作用都是返回一个新的对象,但foo修改了入参,所以foo不是纯函数,bar没有产生任何副作用,满足纯函数的定义。

使用纯函数在开发当中具有一些优点

  • 不用考虑传入的参数是否已经发生了变化
  • 不用考虑函数的操作是否会修改全局、外部的一些变量

这样函数的功能就更加的单一和纯净,可以放心的编写和使用

柯里化

通过函数返回函数的方式,实现多次接收参数并进行统一处理的函数编码形式

function sum(a, b, c) {
  return a + b + c
} // 柯里化写法
function add(a) {
  return function (b) {
    return function (c) {
      return a + b + c
    }
  }
}
sum(1, 2, 3)
add(1)(2)(3)

以上两个函数的执行结果相同,但是调用方式不同,使用柯里化的优点在于使每一个函数的功能更加单一,及逻辑复用

function foo(type, time, message){
  console.log(`${type}:${[time]}:${message}`)
}
foo('error', '2021/10/24', '接口返回数据异常')
foo('error', new Date(), '页面显示错误') // 柯里化写法
function log(type) {
  return function (time) {
    return function (message) {
      console.log(`${type}:${[time]}:${message}`)
    }
  }
} var error = log('error')
error('2021/10/24')('接口返回数据异常')
error(new Date())('页面显示错误')

如以上柯里化代码,复用了【获取类型】部分的函数

组合函数

组合函数不是一种函数类型,只是创建一个新函数将多种功能的函数合并起来

function mul(m) {
  return m * 2
} function square(n) {
  return n * n
} // 组合函数
function compose(m, n) {
  return function (i) {
    return m(n(i))
  }
} var fn = compose(mul, square)
console.log(fn(5))

通过组合函数,就可以将不同功能的函数组合使用

with语句

with语句可以创建一个独立的作用域

with语句的语法是 with(){},with小括号内需要传递一个值,一般为对象,with语句内的变量会从这个小括号里先查找

var message = 'global'
var obj = { name: 'alice', message: 'obj' } function foo() {
  console.log(message)
  with (obj) {
    console.log(message)
  }
}
foo()

以上代码的执行结果如下

目前with语句已经不推荐使用了

eval

eval用于解析字符串及执行代码

var str = "var message = 'global'; console.log(message)"
eval(str)

以上代码执行完成会在控制台上输出 global

目前已经不推荐使用eval,从上述代码,我们可以看出它存在的问题

  • 可读性非常差,也不便于维护
  • eval字符串很可能会在执行的过程中被篡改,容易遭到攻击
  • js代码在解析的过程中可以经过js引擎优化,如果是字符串,就没办法优化

严格模式

在全局或者函数中通过 "use strict" 来开启严格模式,严格模式下,不允许编写一些松散的代码,浏览器会对代码进行更严格的检测

严格模式对javascript语义做了一些限制

1、严格模式通过【抛出错误】来消除一些原有的【静默】错误

静默错误:比如定义变量没有关键字声明,如 num = 1

2、严格模式在js引擎在执行代码的时候可以进行更多的优化(不需要对特殊的语法进行处理)

如以下代码,通过属性描述符定义name属性为不可修改

var obj = {}
Object.defineProperty(obj, "name", { writable: false })
obj.name = "alice"

非严格模式直接忽略赋值,严格模式下会报错

3、严格模式禁用了在ECMAScript未来版本可能会定义的一些语法

如:

关键字 function var new

保留字 class let const (ES5以前)

保留字在未来有可能升级为关键字

非严格模式下以前可以使用保留字作为变量如var let = "abc"

严格模式下会报错

具体来说,严格模式做了以下限制

1、无法意外的创建全局变量

在非严格模式下,没有通过关键字定义的变量会被添加到全局

严格模式下这样的代码执行会抛出异常 message is not defined

 message = "hello"

2、严格模式会使引起静默失败的赋值操作抛出异常

静默失败:silently fail,不报错也没有任何效果

非严格模式下不报错,严格模式下直接抛出异常 Cannot create property 'message' on boolean 'true'

true.name = "alice"

3、严格模式下删除不可删除的属性会抛出异常

非严格模式下不报错,忽略删除操作,严格模式下直接抛出异常 Cannot delete property 'address' of #

js中的函数式编程的更多相关文章

  1. 可爱的 Python : Python中的函数式编程,第三部分

    英文原文:Charming Python: Functional programming in Python, Part 3,翻译:开源中国 摘要:  作者David Mertz在其文章<可爱的 ...

  2. Java 中的函数式编程(Functional Programming):Lambda 初识

    Java 8 发布带来的一个主要特性就是对函数式编程的支持. 而 Lambda 表达式就是一个新的并且很重要的一个概念. 它提供了一个简单并且很简洁的编码方式. 首先从几个简单的 Lambda 表达式 ...

  3. C#中的函数式编程:序言(一)

    学了那么久的函数式编程语言,一直想写一些相关的文章.经过一段时间的考虑,我决定开这个坑. 至于为什么选择C#,在我看来,编程语言分三类:一类是难以进行函数式编程的语言,这类语言包括Java6.C语言等 ...

  4. (数据科学学习手札48)Scala中的函数式编程

    一.简介 Scala作为一门函数式编程与面向对象完美结合的语言,函数式编程部分也有其独到之处,本文就将针对Scala中关于函数式编程的一些常用基本内容进行介绍: 二.在Scala中定义函数 2.1 定 ...

  5. Apache Beam中的函数式编程理念

    不多说,直接上干货! Apache Beam中的函数式编程理念 Apache Beam的编程范式借鉴了函数式编程的概念,从工程和实现角度向命令式妥协. 编程的领域里有三大流派:函数式.命令式.逻辑式. ...

  6. C#中的函数式编程:递归与纯函数(二) 学习ASP.NET Core Razor 编程系列四——Asp.Net Core Razor列表模板页面

    C#中的函数式编程:递归与纯函数(二)   在序言中,我们提到函数式编程的两大特征:无副作用.函数是第一公民.现在,我们先来深入第一个特征:无副作用. 无副作用是通过引用透明(Referential ...

  7. C#中面向对象编程中的函数式编程详解

    介绍 使用函数式编程来丰富面向对象编程的想法是陈旧的.将函数编程功能添加到面向对象的语言中会带来面向对象编程设计的好处. 一些旧的和不太老的语言,具有函数式编程和面向对象的编程: 例如,Smallta ...

  8. 通过代数,数字,欧几里得平面和分形讨论JavaScript中的函数式编程

    本文是对函数式编程范式的系列文章从而拉开了与以下延续一个. 介绍 在JavaScript中,函数只是对象.因此,可以构造函数,作为参数传递,从函数返回或分配给变量.因此,JavaScript具有一流的 ...

  9. Java经典类库-Guava中的函数式编程讲解

    如果我要新建一个java的项目,那么有两个类库是必备的,一个是junit,另一个是Guava.选择junit,因为我喜欢TDD,喜欢自动化测试.而是用Guava,是因为我喜欢简洁的API.Guava提 ...

  10. C#中的函数式编程

    在函数式编程中,可以把函数看作数据.函数也可以作为参数,函数还可以返回函数.比如,LINQ就是基于函数式编程的. 两个例子引出函数式编程 语句式编程可能这样写: string result; ) { ...

随机推荐

  1. 2023-04-11:给你下标从 0 开始、长度为 n 的字符串 pattern , 它包含两种字符,‘I‘ 表示 上升 ,‘D‘ 表示 下降 。 你需要构造一个下标从 0 开始长度为 n + 1 的

    2023-04-11:给你下标从 0 开始.长度为 n 的字符串 pattern , 它包含两种字符,'I' 表示 上升 ,'D' 表示 下降 . 你需要构造一个下标从 0 开始长度为 n + 1 的 ...

  2. 2022-10-15:给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素。 你可以按 任意顺序 返回答案。 要求时间复杂度O(N)。 输入: nums = [1,1,1

    2022-10-15:给你一个整数数组 nums 和一个整数 k ,请你返回其中出现频率前 k 高的元素. 你可以按 任意顺序 返回答案. 要求时间复杂度O(N). 输入: nums = [1,1,1 ...

  3. SQL Server:User, group, or role 'iemis' already exists in the current database.

    --最新的解决方法 --先创建用户帐户,不进行授权,然后通过下面的SQL语句将该用户帐户关联至对应的数据库用户.优点是避免了重新授权的操作. USE tempdbEXEC sp_change_user ...

  4. 【GiraKoo】安装Visual Assist失败,提示“此扩展已经安装到所有适用的产品”

    [问题解决]安装Visual Assist失败,提示"此扩展已经安装到所有适用的产品" 在安装Visual Assist插件时,提示错误. 点击下一步之后,进入插件安装界面.插件安 ...

  5. pupstudy的使用

    打开环境 点击管理--打开根目录 把靶场放在www文件夹里 网页打开127.0.0.1/靶场文件名即可

  6. 7-8 切分表达式——写个tokenizer吧 (20 分)

    1.题目描述: [先说点出题背景] 这个题是为低年级同学.学C语言的同学准备的,因为,对这部分同学,这个题目编写起来略有一点复杂.如果是高年级.学过了正则表达式(Regular Expression) ...

  7. react 代码自动格式化

    咦写了几行代码发现保存后没有被格式化? import React from "react"; import {Row,Col } from "antd"; ex ...

  8. ESlint配置详解

    开发中出现eslint提示代码格式错误,有时候不明白其配置规范,是件很头疼的事情到处找api又是半天:so记录一份配置详情便于开发中翻阅 { // 环境定义了预定义的全局变量. "env&q ...

  9. 让优惠再续一年!SHPC 老客专享

    最近云筏君经常收到自家小伙伴发来的关于产品活动的关心慰问,掐指一算,哦,原来是一年一度大家喜闻乐见的剁手节(学名"双十一")马上要来了! 大家都知道,云筏家的产品向来主打高性价比, ...

  10. 2023安洵杯web两道WP

    Web CarelessPy 在首页提示存在eval和login的路由,在download存在任意文件下载 访问eval可以读取目录下的文件,知道/app/pycache/part.cpython-3 ...