【JavaScript】高级语法——纯函数

理解JavaScript中的纯函数

纯函数的维基百科定义:

  • 在程序设计中,若一个函数符合一下条件那么这个函数被称为纯函数:
  • 此函数在相同的输入值时,需产生相同的输出。
  • 函数的输出和输入值以外的其他隐藏信息或状态无关,也和由I/O设备产生的外部输出无关。
  • 该函数不能有语义上可观察的函数副作用,诸如:“触发事件”,使输出设备输出,或更改输出值以外物件的内容等。

简单可理解为一下两点:

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

副作用(side effect)概念:
在计算机科学中,副作用的概念,表示在执行一个函数时,除了返回函数值之外,还对调用函数产生了附加的影响,比如修改了全局变量,修改参数或者改变外部的存储;

一、slice()splice()方法谁是纯函数?

说了那么多,还是实际操作一下比较好,如下代码展示两个数组的处理方法:slice()splice()方法:

slice()

slice() 方法返回一个新的数组对象,这一对象是一个由 beginend 决定的原数组的浅拷贝(包括 begin,不包括end)。原始数组不会被改变。

  • 语法:
      arr.slice([begin[, end]])
    
  • 参数:
    • begin:
      提取起始处的索引(从 0 开始),从该索引开始提取原数组元素。
      如果该参数为负数,则表示从原数组中的倒数第几个元素开始提取,slice(-2) 表示提取原数组中的倒数第二个元素到最后一个元素(包含最后一个元素)。
      如果省略 begin,则 slice 从索引 0 开始。
      如果 begin 大于原数组的长度,则会返回空数组。
    • end:
      提取终止处的索引(从 0 开始),在该索引处结束提取原数组元素。slice 会提取原数组中索引从beginend 的所有元素(包含 begin,但不包含 end)。
      如果该参数为负数, 则它表示在原数组中的倒数第几个元素结束抽取。 slice(-2,-1) 表示抽取了原数组中的倒数第二个元素到最后一个元素(不包含最后一个元素,也就是只有倒数第二个元素)。
      如果 end 被省略,则 slice 会一直提取到原数组末尾。
      如果 end 大于数组的长度,slice 也会一直提取到原数组末尾。
  • 返回值:
    一个含有被提取元素的新数组。

splice()

splice() 方法通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容。此方法会改变原数组。

  • 语法:
  array.splice(start[, deleteCount[, item1[, item2[, ...]]]])
  • 参数:
    • start:指定修改的开始位置(从0计数)。如果超出了数组的长度,则从数组末尾开始添加内容;如果是负值,则表示从数组末位开始的第几位(从-1计数,这意味着-n是倒数第n个元素并且等价于array.length-n);如果负数的绝对值大于数组的长度,则表示开始位置为第0位。
    • deleteCount:可选值,
      整数,表示要移除的数组元素的个数。
      如果 deleteCount 大于 start 之后的元素的总数,则从 start 后面的元素都将被删除(含第 start 位)。
      如果 deleteCount 被省略了,或者它的值大于等于array.length - start(也就是说,如果它大于或者等于start之后的所有元素的数量),那么start之后数组的所有元素都会被删除。
      如果 deleteCount 是 0 或者负数,则不移除元素。这种情况下,至少应添加一个新元素。
    • item1, item2, … :可选值,要添加进数组的元素,从start 位置开始。如果不指定,则splice()将只删除数组元素。
  • 返回值:
    由被删除的元素组成的一个数组。如果只删除了一个元素,则返回只包含一个元素的数组。如果没有删除元素,则返回空数组。

示例代码如下:

var myFish = ['angel', 'clown', 'mandarin', 'sturgeon'];
var removed = myFish.splice(2);
console.log(removed) // [ 'mandarin', 'sturgeon' ]
console.log(myFish) // [ 'angel', 'clown' ]   
// 可以看出myFish数组经过splice函数的处理后,改变了原数组的值


var nums = [10, 20, 30, 40];
var sliceNum = nums.slice(0, 3)
console.log(sliceNum) // [ 10, 20, 30 ]
console.log(nums) // [ 10, 20, 30, 40 ]

有上述示例代码可见:slice函数本身是一个纯函数,splice函数本身不是一个纯函数。

二、纯函数的案例练习

话不多说,直接上案例。

案例一:

示例代码如下:

function foo1 (num1, num2) {
    return num1 * 2 + num2 * num2
}

foo1是纯函数,首先满足相同的输入一定产生相同的输出,其次满足在函数执行过程中,不会产生任何副作用

案例二:

示例代码如下:

var name = "abc"
function foo2 () {
    console.log("foo2正在执行,属于其他执行内容")
    name = "qbz"
}
foo2()

foo2 不是一个纯函数,因为它修改了外界的全局变量name

案例三:

示例代码如下:

function foo3 (info) {
    info.age = 30
}

var obj1 = { name: '21', age: 100 }
foo3(obj1)
console.log(obj1)  // { name: '21', age: 30 }

foo3 不是一个纯函数,因为它修改了传入的参数

案例四:

示例代码如下:

function foo4 (info) {
    return {
        ...obj2,
        age: 100,
    }
}
var obj2 = { name: 'slr', age: 72 }
foo4(obj2)
foo4(obj2)
foo4(obj2)
foo4(obj2) 

foo4是一个纯函数,因为不管我们调用多少次,只要传入的参数obj2不变,得到的输出结果就不变

  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
### 回答1: JavaScript函数是一种可重复使用的代码块,它可以接受输入参数并返回值。函数可以用来组织代码、减少重复代码、提高代码的可读性和可维护性。在JavaScript中,函数可以通过函数声明、函数表达式和箭头函数来定义。函数可以有任意数量的参数,也可以没有参数。函数可以返回任何类型的值,包括数字、字符串、布尔值、对象和函数等。函数可以在全局作用域或局部作用域中定义,也可以作为对象的方法来定义。在JavaScript中,函数是一等公民,可以作为参数传递给其他函数,也可以作为返回值返回给其他函数。 ### 回答2: JavaScript函数是一种非常重要的概念,它允许我们定义一段可重复使用的代码片段,同时还可以让我们更好的组织和管理程序的结构。在JavaScript中,函数可以作为一个值进行处理,可以使用函数表达式或函数声明定义。 函数声明是定义函数的最简单方式,它使用“function”关键字和函数名称来声明一个函数,例如: ``` function greeting() { console.log("Hello World"); } ``` 这里定义了一个简单的函数,功能是输出“Hello World”到控制台。我们可以通过使用函数名来调用它: ``` greeting(); ``` 输出结果为“Hello World”。 除了函数声明外,还有一种常见的函数定义方式——函数表达式。函数表达式是定义一个函数并将其赋值给一个变量,例如: ``` var greeting = function() { console.log("Hello World"); }; ``` 这里定义了一个变量greeting,并将一个匿名函数赋值给它。我们可以通过使用变量名来调用该函数: ``` greeting(); ``` 输出结果为“Hello World”。 JavaScript函数支持一个特殊的参数对象——arguments对象,它可以让我们在函数内部访问到所有传递给该函数的参数。例如: ``` function sum() { var result = 0; for (var i = 0; i < arguments.length; i++) { result += arguments[i]; } return result; } ``` 这里定义了一个函数sum,它可以计算任意数量的参数的和。我们可以使用以下代码来调用该函数并输出结果: ``` console.log(sum(1, 2, 3, 4)); //输出10 console.log(sum(10, 20)); //输出30 ``` 总的来说,JavaScript函数是一项非常重要的技能,它可以帮助我们更好的组织和管理我们的程序,并且可以帮助我们构建可重复使用的代码片段。掌握JavaScript函数,是掌握JavaScript编程的重要一步。 ### 回答3: JavaScript是目前世界上最流行的动态编程语言之一,已成为很多网站和Web应用程序的必选之一。JavaScript函数是编写高度可重复使用的代码和组织逻辑的基本组成部分,也是JavaScript编程的核心。随着Web应用场景的复杂化,函数JavaScript编程中的重要性越来越得到了认识和应用,学习和掌握JavaScript函数是很有必要的。 JavaScript函数与其他编程语言中的函数类似,是一个代码块,可以接受参数,返回值,并可重复使用。JavaScript函数有两种常用的定义方式,分别是函数声明和函数表达式。函数声明是指在代码中提前声明一个函数函数表达式是指将一个函数赋值给一个变量或常量。 在JavaScript函数中,参数和返回值都是可以选择性的。一个函数可以不需要参数也不需要返回值,也可以仅需要参数或仅需要返回值。使用参数可以让函数更加灵活和通用,参数可以是任何类型,包括字符串、数字、函数和对象等。返回值可以是任何JavaScript支持的类型,包括布尔类型、数字类型、字符串类型和数组等。 函数的作用域是JavaScript函数编程中的一个关键概念,它指的是一段代码能够访问和操作的变量和函数的范围。JavaScript函数有词法作用域,即变量的作用域取决于它们在代码中的位置,作用范围被限定在函数内部和它所嵌套的函数中。 常用的JavaScript函数应用包括数组和对象的处理、事件处理和DOM操作等。在Web开发中,JavaScript函数和jQuery库的结合应用很广泛,它可以极大地提高Web应用的交互性和用户体验。 总之,JavaScript函数是一个必须掌握的编程概念,它可以让我们的代码更加灵活、通用、数据安全、易使用和易维护。了解JavaScript函数语法和应用场景,能够有效地提高JavaScript编程的效率和质量。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

不苒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值