我的编程空间,编程开发者的网络收藏夹
学习永远不晚

es6数组中可不可以用展开符

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

es6数组中可不可以用展开符

这篇文章主要讲解了“es6数组中可不可以用展开符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6数组中可不可以用展开符”吧!

es6数组可以用展开符。展开符“...”会将可迭代对象展开到其单独的元素中,而所谓的可迭代对象就是任何能用“for of”循环进行遍历的对象,例如数组、字符串、Map 、Set;当展开符用于数组,可以将一个数组转为用逗号分隔的参数序列。

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

展开运算符(spread operator)允许一个表达式在某处展开。展开运算符在多个参数(用于函数调用)或多个元素(用于数组字面量)或者多个变量(用于解构赋值)的地方可以使用。

es6展开符的使用(数组方面)

1、复制数组

给定一个数组,想要将一个数组的成员复制到另一个数组中,该怎么做?

const a = [1, 2];const b = a;console.log(b); // [1, 2]

真有表面上这么简单吗?试着修改一下a数组中的值

a[0] = 3;console.log(b); // [3, 2]

诶?怎么我修改了a数组中的值,结果b数组中的值也变了?这里涉及到的是堆栈的原理,就不具体展开说了,你只需要知道简单地使用两边相等的方式是不能完成数组的复制的,这里使用展开运算符就可以完成啦?

const a = [1, 2];const c = [...a];console.log(c); // [1, 2]a[0] = 3;console.log(c); // [1, 2]

2、合并数组

const a = [1, 2];const b = [3];const c = [4, 5];console.log([...a, ...b, ...c]); // [1, 2, 3, 4, 5]console.log([...c, ...a, ...b]); // [4, 5, 1, 2, 3]console.log([99, ...a, 24, ...b, ...c]); // [99, 1, 2, 24, 3, 4, 5]

3、字符串转为数组

前置知识:字符串可以按照数组的形式展开?

const name = 'Jae';console.log(...name); // J a e

字符串转数组除了用 split() 方法,也可以用展开运算符?

const name = 'Jae';const name_string = [...name];console.log(name_string); // ["J", "a", "e"]

4、常见的类数组转化为数组

为什么要将类数组转化为数组呢?因为类数组不能使用数组的方法,将其转化过来对于一些对数据进行处理的需求就更加方便了 ~

  • arguments

function func() {console.log(arguments);}func(1, 2); // Arguments(2) [1, 2, callee: ƒ, Symbol(Symbol.iterator): ƒ]// 使用展开远算符function func() {console.log([...arguments]);}func(1, 2); // [1, 2]

  • NodeList

<!--HTML代码--><p>1</p><p>2</p><p>3</p>
const a = document.querySelectAll("p");console.log(a); // NodeList(3) [p, p, p]console.log([...a]); // [p, p, p]

感谢各位的阅读,以上就是“es6数组中可不可以用展开符”的内容了,经过本文的学习后,相信大家对es6数组中可不可以用展开符这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

es6数组中可不可以用展开符

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

es6数组中可不可以用展开符

这篇文章主要讲解了“es6数组中可不可以用展开符”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“es6数组中可不可以用展开符”吧!es6数组可以用展开符。展开符“...”会将可迭代对象展开到其
2023-07-04

php数组中key可不可以是字符

这篇“php数组中key可不可以是字符”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“php数组中key可不可以是字符”文章吧
2023-06-30

php中数组的键名可不可以重复

今天小编给大家分享一下php中数组的键名可不可以重复的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。php数组的键名不可以重复
2023-06-30

php数组中key可以是字符吗

php数组的键名(key)可以是字符。在php中,统一将字符和字符串当作字符串数据类型,而数组的键名(key)可以是整数类型和字符串类型;因此数组的键名(key)可是整数值、单个字符、字符串或字符与数字混合。本教程操作环境:windows7系统、PHP7.1版、DELL G3电脑php数组的键名(key)可以是字符。在其它语言中,字符和字符串是两种不同的数据类型,但在 PHP 中,统一将字符和字符串
2022-06-14

php数组中的元素可不可以是变量

今天小编给大家分享一下php数组中的元素可不可以是变量的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。PHP数组中的元素可以是
2023-07-02

linux可不可以将用户从组中删除

这篇文章主要讲解了“linux可不可以将用户从组中删除”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“linux可不可以将用户从组中删除”吧!可以。删除方法:1、
2023-03-20

php可以不用数组函数往数组添加元素吗

php可以不用数组函数往数组添加元素。在PHP中可以利用数组字面量“[]”来往数组尾部添加元素,语法“$数组变量名[下标]=值”,其中下标(索引值)可以是一个字符串或一个整数;注意下标值不可重复,因此不能设置为已有值。当不在方括号“[]”内指定具体的索引值(下标)时,默认为数字索引,且索引值会从原数字索引的基础上依次增加。
2022-11-17

华为云服务器无数据盘可不可以用移动硬盘打开

首先,使用移动硬盘打开华为云服务器上的数据盘非常简单。只需要在服务器上找到相应的移动硬盘驱动,右键点击它并选择“以管理员权限打开”即可。如果您不熟悉操作,可以查阅相关文档或向华为云服务器的技术支持人员寻求帮助。在使用移动硬盘打开数据盘时,您需要注意以下几点。首先,移动硬盘需要在服务器上有正确的位置,并且处于联网状态。其
2023-10-27

PHP中使用哪些函数可以随机洗牌数组?

php 中有以下函数可以随机洗牌数组:shuffle() 直接改变数组元素顺序。array_rand() 返回随机键,可根据键重新排列数组顺序。PHP 中随机洗牌数组的函数在 PHP 中,有几个函数可以用来随机洗牌数组,使其元素的顺序发生
PHP中使用哪些函数可以随机洗牌数组?
2024-05-01

在golang中,我可以使用flag包来定义一个可以选择接受字符串参数的标志吗?

问题内容我想做的是能够运行这三个场景:cmd --test --branchreleasecmd --测试全部 --branch releasecmd --分支发布能够在没有参数(如布尔值)的情况下自行指定 --test ,并且还
在golang中,我可以使用flag包来定义一个可以选择接受字符串参数的标志吗?
2024-02-06

为什么可以Python中使用f-string 连接字符串与数字

本篇文章为大家展示了为什么可以Python中使用f-string 连接字符串与数字,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。下面以字符串和数字为例,看看强行操作会产生什么结果:>>> "Pyth
2023-06-06

具有 3 个不同指针类型的参数(可以为 nil)的 Sprintf。三元运算符不可用,如何避免写几十行?

php小编子墨在这里为大家解答一个关于Sprintf函数的问题。有时候我们需要使用Sprintf函数来格式化字符串,但是在某些情况下,我们可能会遇到具有三种不同指针类型的参数的情况,而且这些参数可能为nil。在这种情况下,我们无法使用三元运
具有 3 个不同指针类型的参数(可以为 nil)的 Sprintf。三元运算符不可用,如何避免写几十行?
2024-02-12

怎么用JS验证逗号隔开可以是中文字母数字

本文小编为大家详细介绍“怎么用JS验证逗号隔开可以是中文字母数字”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么用JS验证逗号隔开可以是中文字母数字”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。具体代码如下所
2023-07-04

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录