TypeScript: Перечисления (Enums)
В этом уроке мы познакомимся с перечислением. Такая конструкция языка позволяет создать набор имен, а затем обращаться к ним.
Использование перечислений
Перечисления используют вместо строк для постоянных значений:
enum OrderStatus {
Created,
Paid,
Shipped,
Delivered,
}
const order = {
items: 3,
status: OrderStatus.Created,
};
Самый распространенный пример использования перечислений — хранение разных статусов. Но есть и другие случаи. Например, с их помощью хранят различные справочные данные и избавляются от магических значений:
- Направления движения
- Стороны света
- Дни недели
- Месяцы
enum CardinalDirection {
North,
South,
East,
West,
}
const direction = CardinalDirection.North;
Перечисление — это и значение, и тип. Его можно указывать как тип в параметрах функции:
setStatus(status: OrderStatus)
Также перечисления после компиляции превращаются в JavaScript-объект, в котором каждому значению соответствует свойство. У этого свойства есть тип number
и начинается он с 0
:
const status = OrderStatus.Created;
console.log(status); // 0
Это позволяет в дальнейшем удобно использовать стандартные методы — например, Object.keys
и Object.values
:
const statuses = Object.keys(OrderStatus);
console.log(statuses); // ['0', '1', '2', '3', 'Created', 'Paid', 'Shipped', 'Delivered']
Среди ключей мы видим числа '0', '1', '2', '3'
. Компилятор создает такие числовые ключи автоматически, а созданный объект выглядит так:
console.log(OrderStatus); // =>
// {
// '0': 'Created',
// '1': 'Paid',
// '2': 'Shipped',
// '3': 'Delivered',
// 'Created': 0,
// 'Paid': 1,
// 'Shipped': 2,
// 'Delivered': 3
// }
Но можно избавиться от создания дополнительных ключей, если указать строковые значения:
enum OrderStatus {
Created = '0',
Paid = '1',
Shipped = '2',
Delivered = '3',
}
const statuses = Object.keys(OrderStatus);
console.log(statuses); // ['Created', 'Paid', 'Shipped', 'Delivered']
console.log(OrderStatus); // =>
// 'Created': '0',
// 'Paid': '1',
// 'Shipped': '2',
// 'Delivered': '3'
// }
Выводы
В этом уроке мы узнали, для чего и как используется перечисление. Также мы разобрали, что его можно указывать как тип в параметрах функции.
Задание
- Реализуйте перечисление
ModalStatus
с двумя значениями: Opened и Closed - Реализуйте функцию
buildModal()
. Он возвращает объект, который описывает модальное окно. Параметры функции:
- Текст, который должен быть внутри окна после инициализации
- Статус, с которым надо создать объект окна
Функция возвращает объект с двумя полями: text
(здесь хранится переданный текст) и status
(здесь хранится переданный статус)
const modal = buildModal('hexlet forever', ModalStatus.Opened);
// { text: 'hexlet forever', status: ModalStatus.Opened }
Упражнение не проходит проверку — что делать? 😶
Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:
- Обязательно приложите вывод тестов, без него практически невозможно понять что не так, даже если вы покажете свой код. Программисты плохо исполняют код в голове, но по полученной ошибке почти всегда понятно, куда смотреть.
В моей среде код работает, а здесь нет 🤨
Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.
Мой код отличается от решения учителя 🤔
Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.
В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.
Прочитал урок — ничего не понятно 🙄
Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.
Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.