В разработке на 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' }]
Для полного доступа к курсу нужен базовый план
Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.