es6中扩展运算符如何用(es6,web开发)

时间:2024-04-19 20:00:12 作者 : 石家庄SEO 分类 : web开发
  • TAG :

希望大家仔细阅读,能够学有所成!

es6扩展运算符的用法:1、复制数组,语法“[...数组]”;2、合并数组,语法“[...数组1, ...数组2]”;3、向数组中添加元素,语法“[...数组, '元素值']”;4、和Math对象一起使用,计算最大值、最小值或者总和;5、向函数传递无限参数,语法“const myFunc=(...args)=>{};”;6、将字符串转字符数组,语法“[...字符串]”。

本教程操作环境:windows7系统、ECMAScript 6版、Dell G3电脑。

es6中扩展运算符介绍

扩展操作符 … 是ES6中引入的,将可迭代对象展开到其单独的元素中,所谓的可迭代对象就是任何能用for of循环进行遍历的对象,例如:数组(数组常用方法)、字符串、Map (悟透Map)、Set (Set 如何使用?)、DOM节点等。

它好比 rest 参数的逆运算,将一个数组转为用逗号分隔的参数序列。扩展运算符与正常的函数参数可以结合使用,后面也可以放置表达式,但如果后面是一个空数组,则不产生任何效果。

letarr=[];
arr.push(...[1,2,3,4,5]);
console.log(arr);//[1,2,3,4,5]
console.log(1,...[2,3,4],5)//12345
console.log(...(1>0?['a']:[]));//a
console.log([...[],1]);//[1]

意义

替代函数的apply方法

由于扩展运算符可以展开数组,所以不再需要apply方法,将数组转为函数的参数了。

扩展运算符(...)的10+种用法

1、复制数组

我们可以使用展开操作符复制数组,不过要注意的是这是一个浅拷贝

constarr1=[1,2,3];
constarr2=[...arr1];
console.log(arr2);
//[1,2,3]

这样我们就可以复制一个基本的数组,注意,它不适用于多级数组或带有日期或函数的数组。

2、合并数组

假设我们有两个数组想合并为一个,早期间我们可以使用concat方法,但现在可以使用展开操作符:

constarr1=[1,2,3];
constarr2=[4,5,6];
constarr3=[...arr1,...arr2];
console.log(arr3);
//[1,2,3,4,5,6]

我们还可以通过不同的排列方式来说明哪个应该先出现。

constarr3=[...arr2,...arr1];
console.log(arr3);
[4,5,6,1,2,3];

此外,展开运算符号还适用多个数组的合并:

constoutput=[...arr1,...arr2,...arr3,...arr4];

3、向数组中添加元素

letarr1=['this','is','an'];
arr1=[...arr1,'array'];
console.log(arr1);
//['this','is','an','array']

4、向对象添加属性

假设你有一个user 的对象,但它缺少一个age属性。

constuser={
firstname:'Chris',
lastname:'Bongers'
};

要向这个user对象添加age,我们可以再次利用展开操作符。

constoutput={...user,age:31};

5、使用 Math() 函数

假设我们有一个数字数组,我们想要获得这些数字中的最大值、最小值或者总和。

constarr1=[1,-1,0,5,3];

为了获得最小值,我们可以使用展开操作符和 Math.min 方法。

constarr1=[1,-1,0,5,3];
constmin=Math.min(...arr1);
console.log(min);
//-1

同样,要获得最大值,可以这么做:

constarr1=[1,-1,0,5,3];
constmax=Math.max(...arr1);
console.log(max);
//5

如大家所见,最大值5,如果我们删除5,它将返回3

你可能会好奇,如果我们不使用展开操作符会发生什么?

constarr1=[1,-1,0,5,3];
constmax=Math.max(arr1);
console.log(max);
//NaN

这会返回NaN,因为JavaScript不知道数组的最大值是什么。

6、rest 参数

假设我们有一个函数,它有三个参数。

constmyFunc(x1,x2,x3)=>{
console.log(x1);
console.log(x2);
console.log(x3);
}

我们可以按以下方式调用这个函数:

myFunc(1,2,3);

但是,如果我们要传递一个数组会发生什么。

constarr1=[1,2,3];

我们可以使用展开操作符将这个数组扩展到我们的函数中。

myFunc(...arr1);
//1
//2
//3

这里,我们将数组分为三个单独的参数,然后传递给函数。

constmyFunc=(x1,x2,x3)=>{
console.log(x1);
console.log(x2);
console.log(x3);
};
constarr1=[1,2,3];
myFunc(...arr1);
//1
//2
//3

7、向函数传递无限参数

假设我们有一个函数,它接受无限个参数,如下所示:

constmyFunc=(...args)=>{
console.log(args);
};

如果我们现在调用这个带有多个参数的函数,会看到下面的情况:

myFunc(1,'a',newDate());

返回:

[
1,
'a',
Date{
proto:Date{}
}
]

然后,我们就可以动态地循环遍历参数。

8、将 nodeList 转换为数组

假设我们使用了展开运算符来获取页面上的所有p

constel=[...document.querySelectorAll('p')];
console.log(el);
//(3)[p,p,p]

在这里可以看到我们从dom中获得了3个p

现在,我们可以轻松地遍历这些元素,因为它们是数组了。

constel=[...document.querySelectorAll('p')];
el.forEach(item=>{
console.log(item);
});
//<p></p>
//<p></p>
//<p></p>

9、解构变量

解构对象

假设我们有一个对象user:

constuser={
firstname:'Chris',
lastname:'Bongers',
age:31
};

现在,我们可以使用展开运算符将其分解为单个变量。

const{firstname,...rest}=user;
console.log(firstname);
console.log(rest);
//'Chris'
//{lastname:'Bongers',age:31}

这里,我们解构了user对象,并将firstname解构为firstname变量,将对象的其余部分解构为rest变量。

解构数组

const[currentMonth,...others]=[7,8,9,10,11,12];
console.log(currentMonth);//7
console.log(others);//[8,9,10,11,12]

10、展开字符串(字符串转字符数组)

String 也是一个可迭代对象,所以也可以使用扩展运算符 ... 将其转为字符数组,如下:

consttitle="china";
constcharts=[...title];
console.log(charts);//['c','h','i','n','a']

进而可以简单进行字符串截取,如下:

consttitle="china";
constshort=[...title];
short.length=2;
console.log(short.join(""));//ch

11、数组去重

与 Set 一起使用消除数组的重复项,如下:

constarrayNumbers=[1,5,9,3,5,7,10,4,5,2,5];
console.log(arrayNumbers);
constnewNumbers=[...newSet(arrayNumbers)];
console.log(newNumbers);//[1,5,9,3,7,10,4,2]

登录后复制

es6中扩展运算符如何用

12、打印日志

在打印可迭代对象的时候,需要打印每一项可以使用扩展符,如下:

constyears=[2018,2019,2020,2021];
console.log(...years);//2018201920202021

本文:es6中扩展运算符如何用的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:react hooks实现原理源码分析下一篇:

11 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18