(...)这三个点在JavaScript中意味着什么?

时间: 2018-08-29阅读: 5246标签: js知识

这篇文章的标题来自我在Quora上被要求回答的一个问题。下面是我试图解释JavaScript中三个点的作用。希望这对于将来有相同问题的人来说可以消除围绕这个概念的迷雾。


数组/对象扩展运算符

假设您有以下对象:

const adrian = {
  fullName: 'Adrian Oprea',
  occupation: 'Software developer',
  age: 31,
  website: 'https://oprea.rocks'
};

假设您要创建一个具有不同名称和网站但具有相同职业和年龄的新对象(人)。

您可以通过仅指定所需的属性来执行此操作,并使用扩展运算符来完成其余操作,如下所示:

const bill = {
  ...adrian,
  fullName: 'Bill Gates',
 website: 'https://microsoft.com'
};

上面代码的作用是遍布adrian对象并获取其所有属性,然后用我们传递的属性覆盖现有属性。可以将这种传播视为逐个提取所有单个属性并将它们传递给新对象。

在这种情况下,由于我们在扩展运算符启动后指定了fullName和网站属性,因此JavaScript引擎知道我们要覆盖来自原始对象的那些属性的原始值。

这与阵列类似。除了传播键和值之外,运算符不会传播索引(index)和值。与对象传播不同的是,你不会有重复的属性,因为这是JavaScript对象的工作方式(你不能拥有一个具有两个fullName属性的对象),如果你计划实现类似的东西,那么对于数组你最终可能会有重复的值到我们的对象示例。

这意味着下面的代码将导致您拥有包含重复元素的数组。

const numbers1 = [1, 2, 3, 4, 5];
const numbers2 = [ ...numbers1, 1, 2, 6,7,8]; // this will be [1, 2, 3, 4, 5, 1, 2, 6, 7, 8]

可以把它想象成Array.prototype.concat的替代品.


rest运算符

使用函数的参数时,无论是完全替换参数还是与函数的参数一起替换参数,这三个点也称为rest运算符。

当像这样使用它时,rest操作符使开发人员能够创建可以获取无限数量的参数的函数,也称为变量arity或可变函数。

这是这种功能最简单的例子。假设您要创建一个计算其所有参数之和的函数。请注意,它不是两个,三个或四个数字的总和,而是函数作为参数接收的所有数字的总和。

这是一个简单的实现,使用rest运算符

function sum(...numbers) {
    return numbers.reduce((accumulator, current) => {
        return accumulator += current
    });
};

sum(1,2) // 3
sum(1,2,3,4,5) // 15

最简单的解释是,rest运算符接收函数接收的参数并将它们转储到以后可以使用的实数数组中。

你可能会觉得,你可以通过请求用户传递一组数字来完成此操作。这在技术上是可行的,但是这样的用户体验很差,因为用户希望用普通数字而不是数字列表来调用sum函数。

您可能还认为可以使用arguments数组。这也是事实,但要小心,参数不是真正的数组,而是类似数组的对象(具有length属性的对象)。对于我们的sum函数的第一次调用,在前面的例子中,它实际上看起来像这样:

{
  '0': 1,
  '1': 2,
  'length': 2
}

要操作此对象并在其上使用数组方法,例如reduce,从我之前的示例中,您必须执行Array.prototype.slice.call(arguments,0)操作。就速度和内存使用而言,这表现不佳并且不优雅。这样的代码,容易让你的初级水平的同事感到困惑。

这应该是您需要了解的所有内容,以便在JavaScript中使用rest / spread运算符。


原文链接: oprea.rocks  
翻译来源:https://segmentfault.com/a/1190000016168214
站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

链接: http://www.fly63.com/article/detial/1038

js 实现栈和队列

js实现栈或者队列有两种方式: 1.数组:数组本身提供栈方法(push,pop),队列方法(push,shift)。 2.链表:构造链表结构,说白了就是链表的插入(尾插),移除(栈:末尾节点移除,队列:头结点移除)

JavaScript 进阶问题列表

我在我的 Instagram 上每天都会发布 JavaScript 的选择题,并且同时也会在这个仓库中发布。从基础到进阶,测试你有多了解 JavaScript,刷新你的知识,或者帮助你的 coding 面试!

数字在JavaScript中是如何编译的

JavaScript中的所有数字都是浮点数。这篇博客文章解释了这些浮点数如何在64位二进制内部表示。浮点数并不一定等于小数,定点数也并不一定就是整数。所谓浮点数就是小数点在逻辑上是不固定的,而定点数只能表示小数点固定的数值

为什么JavaScript开发如此疯狂

Web开发中其他一切对你而言都是小菜一碟,但当你深入探究JavaScript的时候,不免有一种“众人皆醒你独醉”的悲壮——好像其他人都知道你不知道的一些大的基础的知识内容,并且这些内容可以帮助你理解所有知识

JS的变量作用域问题,理解js全局变量和局部变量问题

js的变量分为2种类型:局部变量和全局变量。主要区别在于:局部变量是指只能在变量被声明的函数内部调用,全局变量在整个代码运行过程中都可以调用。值得注意的js中还可以隐式声明变量,而隐式声明的变量千万不能当做全局变量来使用。

JavaScript中的行为委托

行为委托简单来说就是一种设计模式,不同于传统的构造函数的类式设计。这里每个例子会通过构造函数,class和行为委托来不同实现,不过不会评论class,是否使用class取决于你的观点。

js中的相等性判断

Js提供了三种不同的比较操作符===,==,Object.is。ECMAScript 提供了四种比较操作符:非严格相等(==)、严格相等(===)、零值相等、同值相等。

JS 超类和子类

看到javascript高级程序设计的面向对象章节看到超类与子类这个概念词,不懂上度娘查了才知道是怎么一回事。说到超类与子类,就不得不提起原型模式,原型对象,原型链与原型链继承了

js基础_如何理解作用域和作用域链?

作用域外,无法引用作用域内的变量;离开作用域后,作用域的变量的内存空间会被清除,比如执行完函数或者关闭浏览器,作用域与执行上下文是完全不同的两个概念。我曾经也混淆过他们,但是一定要仔细区分。JavaScript代码的整个执行过程,分为两个阶段,代码编译阶段与代码执行阶段。

JavaScript中奇特的~运算符

本次分享一下并不是很常用的按位非运算符~的原理以及一点点用法。产生式 UnaryExpression : ~ UnaryExpression 按照下面的过程执行:令 expr 为解释执行 UnaryExpression 的结果。令 oldValue 为 ToInt32(GetValue(expr))。返回 oldValue 按位取反的结果。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!