Сводка
Метод splice()
изменяет содержимое массива, удаляя существующие элементы и/или добавляя новые.
Синтаксис
array.splice(start, deleteCount[, item1[, item2[, ...]]])
Параметры
start
- Индекс, по которому начинать изменять массив. Если больше длины массива, реальный индекс будет установлен на длину массива. Если отрицателен, указывает индекс элемента с конца.
deleteCount
- Целое число, показывающее количество старых удаляемых из массива элементов. Если
deleteCount
равен 0, элементы не удаляются. В этом случае вы должны указать как минимум один новый элемент. ЕслиdeleteCount
больше количества элементов, оставшихся в массиве, начиная с индексаstart
, то будут удалены все элементы до конца массива. itemN
- Необязательные параметры. Добавляемые к массиву элементы. Если вы не укажете никакого элемента,
splice()
просто удалит элементы из массива.
Возвращаемое значение
Массив, содержащий удалённые элементы. Если будет удалён только один элемент, вернётся массив из одного элемента. Если никакие элементы не будут удалены, вернётся пустой массив.
Описание
Если количество указанных вставляемых элементов будет отличным от количества удаляемых элементов, массив изменит длину после вызова.
Примеры
Пример: использование метода splice()
Следующий пример иллюстрирует использование метода splice()
:
var myFish = ['ангел', 'клоун', 'мандарин', 'хирург']; // удаляет 0 элементов с индекса 2 и вставляет элемент 'барабанщик' var removed = myFish.splice(2, 0, 'барабанщик'); // myFish равен ['ангел', 'клоун', 'барабанщик', 'мандарин', 'хирург'] // removed равен [], никакие элементы не были удалены // удаляет 1 элемент с индекса 3 removed = myFish.splice(3, 1); // myFish равен ['ангел', 'клоун', 'барабанщик', 'хирург'] // removed равен ['мандарин'] // удаляет 1 элемент с индекса 2 и вставляет элемент 'телескоп' removed = myFish.splice(2, 1, 'телескоп'); // myFish равен ['ангел', 'клоун', 'телескоп', 'хирург'] // removed равен ['барабанщик'] // удаляет 2 элемента с индекса 0 и вставляет элементы 'попугай', 'анемон' и 'голубая' removed = myFish.splice(0, 2, 'попугай', 'анемон', 'голубая'); // myFish равен ['попугай', 'анемон', 'голубая', 'телескоп', 'хирург'] // removed равен ['ангел', 'клоун'] // удаляет 2 элемента с индекса 3 removed = myFish.splice(3, Number.MAX_VALUE); // myFish равен ['попугай', 'анемон', 'голубая'] // removed равен ['телескоп', 'хирург']
Спецификации
Спецификация | Статус | Комментарии |
---|---|---|
ECMAScript 3-е издание. | Стандарт | Изначальное определение. Реализована в JavaScript 1.2. |
ECMAScript 5.1 (ECMA-262) Определение 'Array.prototype.splice' в этой спецификации. |
Стандарт | |
ECMAScript 2015 (6th Edition, ECMA-262) Определение 'Array.prototype.splice' в этой спецификации. |
Стандарт |
Совместимость с браузерами
Возможность | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Базовая поддержка | 1.0 | 1.0 (1.7 или ранее) | 5.5 | (Да) | (Да) |
Возможность | Android | Chrome для Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Базовая поддержка | (Да) | (Да) | (Да) | (Да) | (Да) | (Да) |
Обратная совместимость
В JavaScript 1.2 метод splice()
возвращал удалённый элемент только если был удалён один элемент (параметр deleteCount
равен 1); в противном случае метод возвращал массив с удалёнными элементами. Обратите внимание, что последним браузером, использующим JavaScript 1.2, был Netscape Navigator 4, так что вы можете считать, что splice()
всегда возвращает массив.