js splice实现
splice 方法的基本概念
JavaScript 的 splice() 方法用于修改数组,可以删除、替换或添加元素。该方法会直接修改原数组,并返回被删除的元素组成的数组。
语法
array.splice(start, deleteCount, item1, item2, ...)
- start:指定修改的起始位置(从 0 开始)。如果为负数,表示从数组末尾开始计算。
- deleteCount(可选):要删除的元素个数。如果为 0 或省略,则不删除元素。
- item1, item2, ...(可选):要添加到数组的元素,从
start位置开始插入。
使用示例
删除元素
const arr = [1, 2, 3, 4, 5];
const removed = arr.splice(1, 2); // 从索引 1 开始删除 2 个元素
console.log(arr); // [1, 4, 5]
console.log(removed); // [2, 3]
替换元素
const arr = [1, 2, 3, 4, 5];
const removed = arr.splice(1, 2, 'a', 'b'); // 从索引 1 开始删除 2 个元素,并插入 'a' 和 'b'
console.log(arr); // [1, 'a', 'b', 4, 5]
console.log(removed); // [2, 3]
添加元素
const arr = [1, 2, 3, 4, 5];
const removed = arr.splice(2, 0, 'a', 'b'); // 从索引 2 开始插入 'a' 和 'b',不删除元素
console.log(arr); // [1, 2, 'a', 'b', 3, 4, 5]
console.log(removed); // []
实现一个简单的 splice
以下是 splice 方法的一个简化实现:

function customSplice(array, start, deleteCount, ...items) {
const deleted = [];
const startIdx = start < 0 ? Math.max(array.length + start, 0) : Math.min(start, array.length);
const actualDeleteCount = Math.min(deleteCount, array.length - startIdx);
// 收集被删除的元素
for (let i = 0; i < actualDeleteCount; i++) {
deleted.push(array[startIdx + i]);
}
// 移动剩余元素
const remaining = array.length - startIdx - actualDeleteCount;
if (items.length < actualDeleteCount) {
// 新元素比删除的元素少,需要向前移动
for (let i = 0; i < remaining; i++) {
array[startIdx + items.length + i] = array[startIdx + actualDeleteCount + i];
}
array.length = array.length - (actualDeleteCount - items.length);
} else if (items.length > actualDeleteCount) {
// 新元素比删除的元素多,需要向后移动
for (let i = remaining - 1; i >= 0; i--) {
array[startIdx + items.length + i] = array[startIdx + actualDeleteCount + i];
}
}
// 插入新元素
for (let i = 0; i < items.length; i++) {
array[startIdx + i] = items[i];
}
return deleted;
}
注意事项
- 原数组修改:
splice会直接修改原数组,使用时需注意。 - 负索引:
start可以为负数,表示从数组末尾开始计算。 - 边界情况:
start超出数组长度时,会从数组末尾开始操作;deleteCount为 0 或负数时,不删除元素。
通过以上示例和实现,可以更好地理解 splice 方法的工作原理和用法。






