JavaScript --- 扩展操作符(...)

本文介绍了JavaScript中的扩展操作符,重点讲解了其在参数扩展与收集方面的应用,包括如何将数组分解为单个参数和如何将多个参数整合成数组,展示了ES6中这一特性在处理集合数据时的便利性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

参数扩展与收集

ES6新增了扩展操作符,使用它可以非常简洁地操作和组合集合数据,可以在接收参数或传递参数时使用

场景一:把数组分为单个参数(扩展参数)

let arr = [25, 65, 12, 77,38];

function getsum() {   //arguments伪数组会默认接收到所有参数
	let sum = 0;
	for(let i = 0; i < arguments.length; i++) {
		sum += arguments[i];
	}
}
/*下面的两个操作是等价的*/
console.log(getsum(...arr));   //217
console.log(getsum(25, 65, 12, 77,38));  //217

//不只如此,您还可以这样使用,传入更多参数
console.log(getsum(3, ...arr));  //220
console.log(getsum(...arr, 45, 12)); //274
console.log(getsum(-5, ...arr, 12));  //224
console.log(getsum(...arr, ...[2, 3, 1]));  //243

场景二:把参数整合为数组 (收集参数)

function getsum(...values) {
	return values.reduce((x,y) => x + y, 0) ;  //0的意思是如果数组是空的返回0,防止报错
}
console.log(getsum(1,5,4));    //=> 10
console.log(getsum(...[2, 56, 24, 12]);  //=> 94
console.log(getsum());   //=> 0

以下情况需要特别注意

function getsum(...values, lastvalue) {}  //这样声明会报错,因为显然lastvalue接收不到任何参数
function getsum(firstvalue, ...values) {} //这样是可以的
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值