JS基础_数组的方法补充slice和splice

本文深入讲解JavaScript中数组的slice()和splice()方法的使用技巧,包括如何通过slice()方法提取数组元素而不修改原数组,以及如何利用splice()方法在修改原数组的同时插入或删除元素。
<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title></title>
		<script type="text/javascript">
			
			var arr = ["孙悟空","猪八戒","沙和尚","唐僧","白骨精"];
			
			/*
			 * slice()
			 * 	- 可以用来从数组提取指定元素
			 * 	- 该方法不会改变元素数组,而是将截取到的元素封装到一个新数组中返回
			 * 	- 参数:
			 * 		1.截取开始的位置的索引,包含开始索引
			 * 		2.截取结束的位置的索引,不包含结束索引
			 * 			- 第二个参数可以省略不写,此时会截取从开始索引往后的所有元素
			 * 		- 索引可以传递一个负值,如果传递一个负值,则从后往前计算
			 * 			-1 倒数第一个
			 * 			-2 倒数第二个
			 */
			
			var result = arr.slice(1,4);  //效果一样:result = arr.slice(1);
			
			result = arr.slice(3); //第二个参数可以省略不写
			
			result = arr.slice(1,-2); //"猪八戒","沙和尚"
			
			//console.log(result);
			

			/*
			 * splice()
			 * 	- 可以用于删除数组中的指定元素
			 * 	- 使用splice()会影响到原数组,会将指定元素从原数组中删除
			 * 		并将被删除的元素作为返回值返回
			 * 	- 参数:
			 * 		第一个,表示开始位置的索引
			 * 		第二个,表示删除的数量
			 * 		第三个及以后。。
			 * 			可以传递一些新的元素,这些元素将会自动插入到开始位置索引前边
			 * 	
			 */
			
			arr = ["孙悟空","猪八戒","沙和尚","唐僧","白骨精"];
			//var result = arr.splice(0,1);//删孙悟空
			var result = arr.splice(3,0,"牛魔王","铁扇公主","红孩儿");
			
			console.log(arr);  //"孙悟空","猪八戒","沙和尚","牛魔王","铁扇公主","红孩儿","唐僧","白骨精"
			//console.log(result);
			
			
		</script>
	</head>
	<body>
	</body>
</html>

 

在 JavaScript 中,`splice()` `slice()` 是数组对象的两个常用方法,它们的功能行为存在显著差异。 ### `slice()` 方法 `slice()` 方法用于从数组中提取一段子数组,并返回一个新的数组。它不会修改原数组,而是返回一个副本。该方法接受两个参数:`start` `end`(可选),分别表示提取的起始位置结束位置(不包含 `end` 位置的元素)。如果省略 `end`,则提取到数组末尾。负数索引可以表示从数组末尾倒数,例如 `-1` 表示最后一个元素 [^3]。 ```javascript const arr = [1, 2, 3, 4, 5]; const subArr = arr.slice(1, 3); console.log(subArr); // [2, 3] console.log(arr); // [1, 2, 3, 4, 5] (原数组未被修改) ``` ### `splice()` 方法 `splice()` 方法用于修改数组的内容,可以删除、插入或替换元素。它会直接修改原数组,并返回一个包含被删除元素的新数组。此方法接受多个参数:`start`(修改的起始位置)、`deleteCount`(要删除的元素个数),以及可选的 `item1, item2, ...`(要添加的新元素)。如果不指定 `deleteCount`,则 `splice()` 只会从 `start` 位置开始删除元素 [^1]。 ```javascript const arr = ["张", "刘", "理想"]; const removed = arr.splice(2, 0, "增加的内容"); console.log(arr); // ["张", "刘", "增加的内容", "理想"] console.log(removed); // [] (未删除元素) ``` ### 主要区别 1. **对原数组的影响**: - `slice()` 不会修改原数组,仅返回一个新数组 [^2]。 - `splice()` 会直接修改原数组,并返回被删除的元素组成的数组 [^5]。 2. **功能差异**: - `slice()` 仅用于提取数组的一部分,适用于需要保留原数组不变的场景 [^3]。 - `splice()` 用于增删改操作,支持删除、插入或替换元素,适用于需要直接修改数组内容的场景 [^1]。 3. **参数处理**: - `slice()` 接受两个参数(`start` `end`),用于定义提取范围 [^3]。 - `splice()` 接受至少两个参数(`start` `deleteCount`),还可以添加新元素 。 4. **返回值**: - `slice()` 返回提取的子数组 [^3]。 - `splice()` 返回被删除元素的数组 。 ### 使用场景 - 如果需要从数组中提取部分数据而不影响原数组,应使用 `slice()` [^2]。 - 如果需要对数组进行增删改操作,应使用 `splice()`,但需要注意其对原数组的影响 。 ### 示例代码 #### `slice()` 示例 ```javascript const arr = [1, 2, 3, 4, 5]; const subArr = arr.slice(1, 3); console.log(subArr); // [2, 3] console.log(arr); // [1, 2, 3, 4, 5] (原数组未被修改) ``` #### `splice()` 示例 ```javascript const months = ['Jan', 'March', 'April', 'June']; months.splice(1, 0, 'Feb'); console.log(months); // ["Jan", "Feb", "March", "April", "June"] months.splice(4, 1, 'May'); console.log(months); // ["Jan", "Feb", "March", "April", "May"] ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值