JavaScript | Как уменьшить длину массива?

JavaScript | Как уменьшить длину массива?

Сокращение длины массива

Иногда требуется уменьшить длину массива. Пусть у нас будет массив massivMinus:

var massivMinus = ["qqq","www","eee","rrr","ttt","yyy"]

Этот массив имеет 6 элементов со значениями. Это полный массив, а значит количество элементов равняется количеству его индексов (6 элементов / 6 индексов). Его индексы: 0, 1, 2, 3, 4, 5

Мы визуально видим, что длина massivMinus равна 6. Давайте узнаем длину и убедимся, что мы правильно определили длину.

massivMinus.length

Всё верно. Длина исходного массива равна шести (6)

 

Видео инструкция

В этом видео приводится пример уменьшения длины массива JavaScript. Массив создан при помощи квадратных скобок. Ввод команд осуществляется в консоль браузера Google Chrome. Результат виден сразу.

Воспользуемся оператором присваивания «=» и установим свойство «length» экземпляра массива на 3. Так мы уменьшим длину массива. Мы прописываем целое число в качестве новой длины.

massivMinus.length = 3

Мы присвоили то что находится справа, тому что находится слева от символа «=». То есть цифру 3 мы присвоили для massivMinus.length. В результате мы ручным способом уменьшили длину массива.

Но давайте теперь подумаем, что стало с самими элементами массива после уменьшения длины. Какое значение элемента массива мы получим под индексом «0», а какое под индексом «5»?

Выведем в консоль наш новый (удлинённый) массив:

console.log(massivMinus)

Посмотрим, что получилось:

Массив с уменьшенной длиной
Массив с уменьшенной длиной

Итоговый (новый) массив лишился трёх последних элементов, под которые не были выделены индексы. В результате мы имеем длину массива 3, но без индексов 3, 4 и 5. Они просто пропали — стёрлись из оперативной памяти. Уменьшение длины массива уничтожило данные.

Уменьшение длины массива опасная операция, если мы говорим о сохранности данных. Противоположная операция — увеличение длины массива, не повреждает данные, хранящиеся в элементах.

 

Альтернативный синтаксис

Можно было использовать иной синтаксис. Например можно из существующей длины массива (6) вычесть 3, чтобы в итоге получить длину 3:

massivMinus.length -= 3

То есть мы бы не просто «присваивали» — сначала «вычитали«, а потом «присваивали«. Результат остался бы прежним:

Уменьшение длины массива на 3
Уменьшение длины массива на 3

 

Информационные ссылки

JavaScript | Массивы (Array)

JavaScript | Как увеличить длину массива?

JavaScript | Как изменить длину массива?

ECMAScriptLiving Standardhttps://tc39.es/ecma262/#sec-array-objects