聊聊前端 JavaScript 的扩展运算符 “...“ 的使用场景

简介: 聊聊前端 JavaScript 的扩展运算符 “...“ 的使用场景

前言

在 JavaScript 中,... 被称为 “扩展运算符” 或 “剩余参数运算符”。

扩展运算符是在 ES6(ECMAScript 2015)中被引入的,目的是为了提高语言的表达能力和代码的可读性。

根据上下文不同,它主要用在数组、对象以及函数调用中,帮助我们更灵活地处理数据结构。

下文说一下它的使用场景。

数组操作

  1. 合并数组
let array1 = [1, 2];
let array2 = [3, 4];
let combinedArray = [...array1, ...array2]; // 结果为 [1, 2, 3, 4]
  1. 复制数组
let originalArray = [1, 2, 3];
let copiedArray = [...originalArray]; 
// 结果为 [1, 2, 3]
  1. 扩展数组
function logElements(...elements) {
    elements.forEach(element => console.log(element));
}
let numbers = [1, 2, 3];
logElements(...numbers); 
// 输出 1 2 3
  1. 解构数组
const arr = [1, 2, 3, 4, 5];
const [first, second, ...rest] = arr;
console.log(first); // 输出: 1
console.log(second); // 输出: 2
console.log(rest); // 输出: [3, 4, 5]

对象操作

  1. 合并对象
let obj1 = { a: 1 };
let obj2 = { b: 2 };
let combinedObj = { ...obj1, ...obj2 }; 
// 结果为 { a: 1, b: 2 }
  1. 复制对象
let originalObj = { a: 1, b: 2 };
let copiedObj = { ...originalObj }; 
// 结果为 { a: 1, b: 2 }
  1. 扩展对象
function logProperties(obj) {
    for (let key in obj) {
        console.log(key + ': ' + obj[key]);
    }
}
let user = { name: 'John', age: 30 };
logProperties({ ...user }); 
// 输出 name: John 和 age: 30

函数调用

函数调用主要是 扩展参数

// 当不确定传入函数的参数数量时,利用扩展运算符将这些参数作为一个数组
function sum(...numbers) {
   return numbers.reduce((acc, curr) => acc + curr, 0);
}
let numbers = [1, 2, 3];
let total = sum(...numbers); 
// 结果为 6

或者

function sum(x, y, z) {
  return x + y + z;
}
//将数组元素作为多个参数传递给函数
const numbers = [1, 2, 3];

总结

... 运算符在 JavaScript 中非常强大且实用。

它使得处理数组和对象的操作更加简洁和直观,尤其是在函数参数、数组或对象的合并和解构时。

不过也要注意这两点:

  • 扩展运算符的复制是浅拷贝,如果对象或数组中含有引用类型的数据,那么拷贝的还是原始对象的引用。
  • 在合并对象时,如果有相同的属性名,后面的属性会覆盖前面的属性。

我是老杨,一个执着于编程乐趣、至今奋斗在一线的 10年+ 资深研发老鸟,是软件项目管理师,也是快乐的程序猿,持续免费分享全栈实用编程技巧、项目管理经验和职场成长心得。欢迎关注老杨的公众号,相互交流,共同进步!


相关文章
|
4天前
|
前端开发 机器人 API
前端大模型入门(一):用 js+langchain 构建基于 LLM 的应用
本文介绍了大语言模型(LLM)的HTTP API流式调用机制及其在前端的实现方法。通过流式调用,服务器可以逐步发送生成的文本内容,前端则实时处理并展示这些数据块,从而提升用户体验和实时性。文章详细讲解了如何使用`fetch`发起流式请求、处理响应流数据、逐步更新界面、处理中断和错误,以及优化用户交互。流式调用特别适用于聊天机器人、搜索建议等应用场景,能够显著减少用户的等待时间,增强交互性。
|
4天前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
16 0
|
5天前
|
JavaScript 前端开发 API
Vue.js:现代前端开发的强大框架
【10月更文挑战第11天】Vue.js:现代前端开发的强大框架
57 41
|
7天前
|
JavaScript 前端开发 API
Vue.js:打造高效前端应用的最佳选择
【10月更文挑战第9天】Vue.js:打造高效前端应用的最佳选择
11 2
|
7天前
|
存储 JavaScript 前端开发
前端开发:Vue.js入门与实战
【10月更文挑战第9天】前端开发:Vue.js入门与实战
|
10天前
|
存储 监控 前端开发
掌握微前端架构:构建可扩展的前端应用
【10月更文挑战第6天】随着前端应用复杂性的增加,传统单体架构已难以满足需求。微前端架构通过将应用拆分为独立模块,提升了灵活性与可维护性。本文介绍微前端的概念、优势及实施步骤,包括定义边界、创建共享UI库、设置通信机制等,并探讨其在SPA扩展、大型项目模块化及遗留系统现代化中的应用。通过实战技巧如版本控制、配置管理和监控日志,帮助团队高效协作,保持应用灵活性。微前端架构为构建大型前端应用提供有效解决方案,适合希望提升项目可扩展性的开发者参考。
|
14天前
|
JavaScript
js运算符
js运算符
18 5
|
4天前
|
JavaScript 前端开发 应用服务中间件
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
vue前端开发中,通过vue.config.js配置和nginx配置,实现多个入口文件的实现方法
34 0
|
4天前
|
前端开发 JavaScript 程序员
【从前端入门到全栈】Node.js 之核心概念
【从前端入门到全栈】Node.js 之核心概念
|
4天前
|
Web App开发 JavaScript 前端开发
前端Node.js面试题
前端Node.js面试题