优雅而高效的JavaScript——扩展运算符

news2024/10/7 6:47:04

在这里插入图片描述

😗博主:小猫娃来啦
😗文章核心:优雅而高效的JavaScript——扩展运算符

文章目录

  • 什么是扩展运算符
    • 扩展运算符的定义
    • 扩展运算符的作用
  • 扩展运算符在数组中的应用
    • 数组的展开
    • 数组的合并
    • 数组的复制
    • 数组的解构赋值
  • 扩展运算符在对象中的应用
    • 对象的展开
    • 对象的合并
    • 对象的复制
    • 对象的解构赋值
  • 扩展运算符在函数中的应用
    • 函数参数的传递
    • 函数返回值的处理
  • 扩展运算符的注意事项
    • 扩展运算符的使用限制
    • 扩展运算符的性能问题
  • 扩展运算符的实战
  • 总结

什么是扩展运算符

扩展运算符的定义

扩展运算符是三个点(…),它可以将一个数组或对象展开成多个元素,或将多个元素合并成一个数组或对象。

扩展运算符的作用

扩展运算符可以用于以下场景:

  • 数组的展、合并、复制和解构赋值
  • 对象的展开、合并、复制和解构赋值
  • 函数参数的传递和返回值的处理

扩展运算符在数组中的应用

数组的展开

使用扩展运算符可以将一个数组展开成多个元素,例如:

const arr = [1, 2, 3];
console.log(...arr); // 1 2 3

数组的合并

使用扩展运算符可以将多个数组合并成一个数组,例如:

const arr1 = [1, 2];
const arr2 = [3, 4];
const arr3 = [...arr1, ...arr2];
console.log(arr3); // [1,2, 3, 4]

数组的复制

使用扩展运算符可以复制一个数组,例如:

const arr1 = [1, 2];
const arr2 = [...arr1];
console.log(arr2); // [1, 2]

数组的解构赋值

数组解构赋值是一种语法,它允许我们从数组中提取值并将它们赋给变量。数组解构赋值的语法使用方括号([])来表示要解构的数组,然后通过等号(=)将解构的值赋给变量。
关于数组解构赋值,总结5点。
关于解构赋值的相关内容也可以去看之前的一篇文章,有详解。
传送门:优雅而高效的JavaScript——解构赋值

  • 基本用法:
const arr = [1, 2, 3];
const [a, b, c] = arr;

console.log(a); // 输出: 1
console.log(b); // 输出: 2
console.log(c); // 输出: 3

  • 忽略某些元素:
const arr = [1, 2, 3, 4, 5];
const [, , c, d] = arr;

console.log(c); // 输出: 3
console.log(d); // 输出: 4
  • 不定元素:
const arr = [1, 2, 3, 4, 5];
const [a, ...rest] = arr;

console.log(a);     // 输出: 1
console.log(rest);  // 输出: [2, 3, 4, 5]
  • 默认值
const arr = [1];
const [a, b = 2] = arr;

console.log(a); // 输出: 1
console.log(b); // 输出: 2
  • 交换变量
let a = 1;
let b = 2;
[a, b] = [b, a];

console.log(a); // 输出: 2
console.log(b); // 输出: 1


扩展运算符在对象中的应用

对象的展开

使用扩展运算符可以将一个对象展开成多个属性,例如:

const obj1 = { a: 1, b: 2 };
const obj2 = { ...obj1, c: 3 };
console.log(obj2); // { a: 1, b: 2, c: 3 }

对象的合并

使用扩展运算符可以将多个对象合并成一个对象,例如:

const obj1 = { a: , b: 2 };
const obj2 = { c: 3, d: 4 };
const obj3 = { ...obj1, ...obj2 };
console.log(obj3); // { a: 1, b: 2, c: 3, d: 4 }

对象的复制

使用扩展运算符可以复制一个对象,例如:

const obj1 = { a: 1, b: 2 };
const obj2 = { ...obj1console.log(obj2); // { a: 1, b: 2 }

对象的解构赋值

使用扩展运算符可以将一个对象解构赋值给多个变量,例如:

const obj = { a: 1, b: 2, c: 3 };
const { a, ...rest } = obj;
console.log(a, rest); // 1 { b: 2, c: 3 }

扩展运算符在函数中的应用

函数参数的传递

使用扩展运算符可以将一个数组或对象作为函数的参数传递,例如:

function sum(a, b, c) {
  return a + b + c}
const arr = [1, 2, 3];
console.log(sumarr)); // 6

function merge(obj1, obj2) {
  return { ...obj1, ...obj2 };
}
const obj1 = { a: 1, b: 2 };
const obj2 = { c: 3, d: 4 };
console.log(merge(obj1, obj2)); // { a: 1, b: 2, c: 3, d: 4 }

函数返回值的处理

使用扩展运算符可以将一个数组或对象作为函数的返回值处理,例如:

function range(start, end) {
  return [...Array(end - start + 1)].map((_, i) => start + i);
}
console.log(range(1, 5)); // [1, 2, 3, 4, 5]

function clone(obj) {
  return { ...obj };
}
const obj1 = { a: 1, b: 2 };
const obj2 = clone(obj1);
console.log(obj2); // { a: 1, b: 2 }

扩展运算符的注意事项

扩展运算符的使用限制

扩展运算符只能用于可迭代对象(如数组、字符串、Set、Map等),不能用于普通对象。

扩展运算符的性能问题

性能问题主要是由于扩展运算符在使用时会创建新的数组或对象,导致内存占用增加和对象复制的开销。特别是在大型数据集上使用扩展运算符时,会占用较多的内存并导致性能下降。

另外,使用扩展运算符进行浅拷贝时,对于嵌套的对象或数组,仅会复制引用而不是真正的拷贝。这可能导致某些意外的副作用,因为原始对象的修改会影响到被复制的对象。

为了解决性能问题,可以考虑以下几点:

  • 对于大型数据集,尽量避免在循环中重复使用扩展运算符。可以考虑使用其他高效的方法来处理数据集,比如使用迭代器、forEach等。

  • 如果需要对数组进行操作,并且不需要创建新的数组,可以直接在原始数组上进行操作,避免使用扩展运算符。

  • 对于深拷贝需求,可以选择其他优化的方法,如使用专门的深拷贝函数或库来处理对象和数组的复制。

扩展运算符的实战

以下是一些使用扩展运算符实战中的代码:

// 数组的展开、合并、复制和解构赋值
const arr1 = [1, 2];
const arr2 = [3, 4];
const arr3 = [...arr1, ...arr2];
const arr4 = [...arr1];
const [a, b] = arr1;

// 对象的展开、合并、复制和解构赋值
const obj1 = { a: 1, b: 2 };
const obj2 = { c: 3, d: 4 };
const obj3 = { ...obj1, ...obj2 };
const obj4 = { ...obj1 };
const { a, b } = obj1;

// 函数参数的传递和返回值的处理
function sum(a, b, c) {
  return a + b + c;
}
const arr = [1, 2, 3];
console.log(sum(...arr)); // 6

function merge(obj1, obj2) {
  return { ...obj1, ...obj2 };
}
const obj1 = { a: 1, b: 2 };
const obj2 = { c: 3, d: 4 };
console.log(merge(obj1, obj2)); // { a: 1, b: 2, c: 3, d: 4 }

总结

扩展运算符是一种非常有用的语法,它可以在数组、对象和函数调用等场景中展开数组或对象,可以实现浅拷贝,实现数组的展开、合并、复制和解构赋值,对象的展开、合并、复制和解构赋值,以及函数参数的传递和返回值的处理。但是,在使用扩展运算符时需要注意其使用限制和性能问题。

在这里插入图片描述


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1090882.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

IDEA创建项目失败提示 Failed to create directory 或 “项目初始化失败”

基本只有一个原因,IDEA对该文件夹操作没有权限 比如你把项目建在了C盘的User文件夹下,User是系统盘,不要乱在里面搞东西 其他教程也许有可能教你文件夹开放权限的方法 但我个人建议,换个普通的文件夹创建项目即可 或者新建个文件…

【计算机毕业设计】python学生成绩补考通知管理系统

经过分析和研究,基于Web的学生成绩管理系统主要包括学生信息管理模块,学生成绩管理模块,学生班级管理模块,学生课程管理模块和系统管理模块。其中信息管理包括信息的浏览和处理,成绩管理包括成绩查询和处理&#xff0c…

【C语言】结构体+位段+枚举+联合(2)

大家好,我是苏貝,本篇博客带大家了解结构体和位段以及枚举,如果你觉得我写的还不错的话,可以给我一个赞👍吗,感谢❤️ 这是这个系列的第二篇,上一篇详细介绍了结构体的基本知识,详情…

基于SSM的高校疫情管理系统的设计与实现

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:Vue 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目:是 目录…

HTML 核心技术点基础详细解析以及综合小案例

核心技术点 网页组成 排版标签 多媒体标签及属性 综合案例一 - 个人简介 综合案例二 - Vue 简介 02-标签语法 HTML 超文本标记语言——HyperText Markup Language。 超文本:链接 标记:标签,带尖括号的文本 标签结构 标签要成…

python基于协同过滤算法商品商城购物推荐系统vue

随着移动互联网的普及,电子商务的发展也引来了新一轮的发展,越来越手动消费者的喜爱,网络经济的发展对国家经济的发展也带来了很大的利好,带动了很多实体经济的转型,用户可以通过网络可以买到自己称心如意的商品&#…

Windows提权方法论

Windows提权方法论 1.溢出漏洞提权2.计划任务提权3.SAM文件提权4.启动项提权5.不带引号的服务路径提权 1.溢出漏洞提权 溢出提权攻击的基本原理是,通过向目标系统发送过长的输入数据,超出了程序所分配的缓冲区大小,导致溢出。攻击者可以利用…

如何理解BFC、开启BFC、BFC解决哪些问题

1.BFC 概念 BFC 英文名为 Block Formatting Context (块级格式化上下文) 具体可查看 MDN 2.BFC的作用 元素开启BFC后,子元素不会发生margin塌陷问题元素开启BFC后,子元素浮动,元素不发生高度塌陷元素开启BFC后,该元素不被其他元…

2023年中国分子筛稀土催化材料竞争格局及行业市场规模分析[图]

稀土催化材料能够起到提高催化剂热稳定性、催化剂活性、催化剂储氧能力,以及减少贵金属活性组分用量等作用,广泛应用于石油化工、汽车尾气净化、工业废气和人居环境净化、燃料电池等领域。 2015-2023年中国稀土催化材料规模及预测 资料来源:…

基于SSM的失物招领信息交互平台

末尾获取源码 开发语言:Java Java开发工具:JDK1.8 后端框架:SSM 前端:Vue 数据库:MySQL5.7和Navicat管理工具结合 服务器:Tomcat8.5 开发软件:IDEA / Eclipse 是否Maven项目:是 目录…

如何用vscode远程连接Linux服务器

文章目录 一、下载所需插件 二、远程连接 三、更改远程服务器名称 一、下载所需插件 打开商店 下载Remote - SSH 下载Remote - SSH扩展包 二、远程连接 点击远程资源管理器 点击SSH旁边的加号 输入:ssh 用户名服务器地址 介绍 第一个是保存到当前用户第二个是保…

2023年中国印花布产量及发展前景分析:数码印花将成为行业趋势[图]

印花布是用坯布印花纸高温印染加工而成,唐宋时期已很盛行,明清时期达到鼎盛。曾深受人们的喜爱,被作为陪嫁被褥、衣服的必备品。印花布上的图案称作花型,瓦栏、花型创意分享平台。 印花布种类 资料来源:共研产业咨询&…

【算法分析与设计】分支限界法(下)

目录 一、最大团问题1.1 问题描述1.2 上界函数1.3 算法思想 二、旅行售货员问题2.1 问题描述2.2 算法描述 三、电路板排列问题3.1 算法描述 四、批处理作业调度问题4.1 问题的描述4.2 限界函数4.3 算法描述 五、小结六、随机化算法 一、最大团问题 1.1 问题描述 给定无向图G(V…

2023年中国智能矿山发展历程及趋势分析:智能矿山健康有序发展[图]

智能矿山系统对矿山生产提质增效的效果已经开始显现:对不合规、有风险的行动进行及时预警,减少安全事故发生概率,避免因停产整顿产生的巨额亏损;精细化管理整个生产流程,避免过往传统粗放的流程导致的浪费,…

2023年中国精准PCI行业发展规模及发展趋势分析:精准PCI日益普及[图]

精准PCI的主要诊断技术包括作为血管内生理学诊断技术的血流储备分数(FFR),以及作为成像技术的血管内超声 (IVUS)及光学相干断层扫描(OCT)。随着功能性和解剖评估的发展,在精密PCI领…

IDEA启动C:\Users\badboy\.jdks\corretto-17.0.7\bin\java.exe -Xmx700m报错

出现的现象 这里没有记录当时的截图,主要报错如下: C:\Users\badboy.jdks\corretto-17.0.7\bin\java.exe -Xmx700m … Error occurred during initialization of VM Failed setting boot class path. 排查方式 遇到这种问题我首先就是百度,…

14.4 Socket 双向数据通信

所谓双向数据传输指的是客户端与服务端之间可以无差异的实现数据交互,此类功能实现的核心原理是通过创建CreateThread()函数多线程分别接收和发送数据包,这样一旦套接字被建立则两者都可以异步发送消息,本章将实现简单的双向交互功能。 首先…

2023年中国光纤传感器发展历程、需求量及行业市场规模分析[图]

光纤传感器是利用光纤作为媒介,将外界温度、应变等被测量转化为光纤中传输的光波的强度、相位、频率、波长、偏振态等光学信息的部件。光纤传感器由光源、入射光纤、出射光纤、光调制器、光探测器及解调器组成。其基本原理是将光源的光经入射光纤送入调制区&#xf…

嵌入式开发学习之STM32F407点亮LED及J-Link下载(二)

嵌入式开发学习之STM32F407点亮LED及J-Link下载(二) 开发涉及工具控制端口配置端口的设定与确认端口配置方法实现点亮LED程序下载与仿真 有工程实例,链接在最底部。 开发涉及工具 开发环境(IDE):IAR-ARM8…

2023年中国尾气净化催化材料产量、需求量及行业市场规模分析[图]

尾气处理催化单元系由催化剂厂商将以催化材料和活性组分物质为主要组成的催化剂涂覆在蜂窝陶瓷或金属等载体上而成,催化剂则起到处理尾气中有害物质的各类化学反应的关键催化作用,主要由稀土材料、氧化铝材料、贵金属材料等催化材料和增强催化材料性能的…