В разработке на JavaScript, где активно применяются функции высшего порядка, такие как map
, filter
и reduce
, массивы меняются редко. Обычно вместо этого создаются новые.
Технически JavaScript не может запретить изменять существующие массивы, поэтому ответственность за соблюдение этого правила лежит на программистах. В этом уроке разберем работу с массивами только для чтения.
Использование неизменяемых массивов
В TypeScript работа с неизменяемыми массивами встроена в систему типов. Чтобы гарантировать неизменяемость, массив помечается модификатором readonly
:
function process(numbers: readonly number[]) {
numbers.push(1); // Error!
}
В этом случае TypeScript выдает ошибку, что тип readonly number[]
не содержит метода push
.
Модификатор readonly
запрещает изменение массива, но не запрещает изменение объектов, которые находятся внутри массива:
const items: readonly ({ key: string })[] = [{ key: 'value'}];
items[0].key = 'another value'; // ok!
Мы успешно изменили значение свойства key
в объекте, который находится внутри массива.
Модификатор readonly
— синтаксический сахар. В случае массива readonly
меняет тип Array
на тип ReadonlyArray
. Как и Array<Type>
, такая запись улучшает читабельность кода, но в остальном не отличается от readonly Type[]
.
Код выше можно было бы записать так:
const items: ReadonlyArray<{ key: string }> = [{ key: 'value'}];
Остались вопросы? Задайте их в разделе «Обсуждение»
Вам ответят команда поддержки Хекслета или другие студенты
Для полного доступа к курсу нужен базовый план
Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.