首页 > web前端 > js教程 > 正文

JS中的...运算符有什么作用?怎么用?

尼克
发布: 2025-06-08 19:51:02
原创
449人浏览过

javascript 中的 ... 运算符主要有三个用途:1. 展开数组或对象元素,用于函数参数传递或合并数组/对象;2. 在函数参数中收集剩余参数,形成数组处理任意数量输入;3. 在解构赋值中收集剩余部分,便于提取或排除特定数据。例如用 [...arr1, ...arr2] 合并数组,用 function sum(...numbers) 处理变参,以及通过 [first, ...rest] 解构获取剩余元素。

JS中的...运算符有什么作用?怎么用?

在 JavaScript 中,... 运算符是一个非常实用的语法,主要用在数组和对象的操作中。它看起来简单,但用途广泛,能让你写出更简洁、易读的代码。


展开数组或对象的内容

... 最常见的一个作用是“展开”数组或对象中的元素。比如你想把一个数组里的所有元素作为参数传给一个函数,或者合并多个数组时,就可以用它。

举个例子:

const arr = [1, 2, 3];
console.log(...arr); // 输出:1 2 3
登录后复制

上面这行代码等价于把数组中的每个元素单独传给 console.log。这种写法在合并数组时特别方便:

const arr1 = [1, 2];
const arr2 = [3, 4];
const combined = [...arr1, ...arr2]; // [1, 2, 3, 4]
登录后复制

对对象也是一样,比如合并两个对象:

const obj1 = { a: 1 };
const obj2 = { b: 2 };
const merged = { ...obj1, ...obj2 }; // { a: 1, b: 2 }
登录后复制

收集函数参数

除了展开,... 还可以用在函数参数中,用来收集“剩余”的参数,也就是我们常说的“rest 参数”。

比如这个例子:

function sum(...numbers) {
  return numbers.reduce((total, num) => total + num, 0);
}

sum(1, 2, 3); // 6
登录后复制

这里的 ...numbers 把传进来的所有参数都收集成一个数组,这样你就可以处理任意数量的参数了。

需要注意的是,在函数定义里,... 只能出现在最后一个参数上,否则会报错。


在解构赋值中使用

... 还可以配合数组或对象的解构使用,把剩下的内容收集起来。

比如从数组中提取前几个元素,剩下的放在一起:

const [first, ...rest] = [1, 2, 3, 4];
console.log(first); // 1
console.log(rest);  // [2, 3, 4]
登录后复制

对象也一样:

const { a, ...others } = { a: 1, b: 2, c: 3 };
console.log(a);     // 1
console.log(others); // { b: 2, c: 3 }
登录后复制

这种写法在处理数据时非常有用,尤其是你需要去掉某些字段或者提取部分数据的时候。


基本上就这些常见用法了。... 看起来只是一个符号,但理解清楚它在不同上下文中的行为,会让你写 JS 更加得心应手。

以上就是JS中的...运算符有什么作用?怎么用?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号