有关 Array.prototype.splice() 方法的详解

Array.prototype.splice()

splice() 方法通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容。此方法会改变原数组

语法

	array.splice(start[, deleteCount[, item1[, item2[, ...]]]])

参数

start
  指定修改的开始位置(从 0 计数)。如果超出了数组的长度,则从数组末尾开始添加内容;如果是负值,则表示从数组末位开始的第几位(从 -1 计数,这意味着 -n 是倒数第 n 个元素并且等价于 array.length - n);如果负数的绝对值大于数组的长度,则表示开始位置为第 0 位。

deleteCount 可选
  整数,表示要移除的数组元素的个数。
  如果 deleteCount 大于 start 之后的元素的总数,则从 start 后面的元素都将被删除(含第 start 位)。
  如果 deleteCount 被省略了,或者它的值大于等于 array.length - start(也就是说,如果它大于或者等于 start 之后的所有元素的数量),那么 start 之后数组的所有元素都会被删除。
  如果 deleteCount0 或者负数,则不移除元素。这种情况下,至少应添加一个新元素。

item1, item2, … 可选
  要添加进数组的元素,从 start 位置开始。如果不指定,则 splice() 将只删除数组元素。

返回值

  被删除的元素组成的一个数组。如果只删除了一个元素,则返回只包含一个元素的数组。如果没有删除元素,则返回空数组。

描述

  如果添加进数组的元素个数不等于被删除的元素个数,数组的长度会发生相应的改变。

示例

  从索引 2 的位置开始删除 0 个元素,插入“drum”

		var myFish = ["angel", "clown", "mandarin", "sturgeon"];
		var removed = myFish.splice(2, 0, "drum");
		
		// 运算后的 myFish: ["angel", "clown", "drum", "mandarin", "sturgeon"]
		// 被删除的元素: [], 没有元素被删除

  从索引 2 的位置开始删除 0 个元素,插入“drum” 和 "guitar"

		var myFish = ['angel', 'clown', 'mandarin', 'sturgeon'];
		var removed = myFish.splice(2, 0, 'drum', 'guitar');
		
		// 运算后的 myFish: ["angel", "clown", "drum", "guitar", "mandarin", "sturgeon"]
		// 被删除的元素: [], 没有元素被删除

  从索引 3 的位置开始删除 1 个元素

		var myFish = ['angel', 'clown', 'drum', 'mandarin', 'sturgeon'];
		var removed = myFish.splice(3, 1);
		
		// 运算后的 myFish: ["angel", "clown", "drum", "sturgeon"]
		// 被删除的元素: ["mandarin"]

  从索引 2 的位置开始删除 1 个元素,插入“trumpet”

		var myFish = ['angel', 'clown', 'drum', 'sturgeon'];
		var removed = myFish.splice(2, 1, "trumpet");
		
		// 运算后的 myFish: ["angel", "clown", "trumpet", "sturgeon"]
		// 被删除的元素: ["drum"]

  从索引 0 的位置开始删除 2 个元素,插入"parrot"、"anemone"和"blue"

		var myFish = ['angel', 'clown', 'trumpet', 'sturgeon'];
		var removed = myFish.splice(0, 2, 'parrot', 'anemone', 'blue');
		
		// 运算后的 myFish: ["parrot", "anemone", "blue", "trumpet", "sturgeon"]
		// 被删除的元素: ["angel", "clown"]

  从索引 2 的位置开始删除 2 个元素

		var myFish = ['parrot', 'anemone', 'blue', 'trumpet', 'sturgeon'];
		var removed = myFish.splice(myFish.length - 3, 2);
		
		// 运算后的 myFish: ["parrot", "anemone", "sturgeon"]
		// 被删除的元素: ["blue", "trumpet"]

  从索引 -2 的位置开始删除 1 个元素

		var myFish = ['angel', 'clown', 'mandarin', 'sturgeon'];
		var removed = myFish.splice(-2, 1);
		
		// 运算后的 myFish: ["angel", "clown", "sturgeon"]
		// 被删除的元素: ["mandarin"]

  从索引 2 的位置开始删除所有元素

		var myFish = ['angel', 'clown', 'mandarin', 'sturgeon'];
		var removed = myFish.splice(2);
		
		// 运算后的 myFish: ["angel", "clown"]
		// 被删除的元素: ["mandarin", "sturgeon"]

转载自 MDN Web Doc 的文章 Array.prototype.splice()

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值