Enum js что это
Перейти к содержимому

Enum js что это

  • автор:

Перечисления в TypeScript

— это удобный способ создания наборов значений, количество и названия которых известны заранее и не должны изменяться. Для создания перечислений используется ключевое слово enum .

Давайте создадим перечисление, содержащее название пор года:

enum Season < Winter, Spring, Summer, Autumn >;

Давайте посмотрим, какие операции можно совершать с перечислениями.

Получение по ключу

Данные в перечислениях можно получать по числовым ключам, подобно элементам массива:

let current: string = Season[0]; console.log(current); // ‘Winter’

Получение по значению

А можно по названию элемента получить его ключ:

let current: number = Season.Winter; console.log(current); // 0

Перечисление как тип

Каждое перечисление создает свой собственный тип данных. Давайте для примера для переменной, хранящей текущий сезон присвоим тип Season :

let current: Season;

Запишем в нашу переменную номер сезона:

let current: Season = Season.Winter; console.log(current); // 0

Можно указать номер сезона вручную:

let current: Season = 3;

А вот если попытаться записать данные другого типа, например, строку, то будет ошибка:

let current: Season = ‘str’; // будет ошибка

К сожалению, диапазон значений не отслеживается и можно записать номер, отсутствующий в нашем перечислении:

let current: Season = 7; // ошибки не будет

При проверке через оператор typeof наша переменная отдаст числовой тип:

let current: Season = 3; console.log(typeof current); // «number»

Подведя итог можно сказать, что такой тип проверяется не сильно строго и от этого его ценность сомнительна.

Указание номеров

Нумерация номеров не обязательно должна быть с нуля. Можно указать ключи в явном виде следующим образом:

enum Season < Winter = 1, Spring = 2, Summer = 3, Autumn = 4 >;
let current: Season = Season.Winter; console.log(current); // выведет 1

Упрощенные ключи

Не обязательно указывать ключи всем элементам. Достаточно указать его первому элементу и ключи следующих элементов будут увеличиваться по порядку. Пример:

enum Season < Winter = 1, Spring, Summer, Autumn >;
let current: Season = Season.Summer; console.log(current); // выведет 3

Строковые перечисления

Ключами могут быть не только числа, но и строки:

enum Season < Winter = 'Зима', Spring = 'Весна', Summer = 'Лето', Autumn = 'Осень' >;
let current: Season = Season.Summer; console.log(current); // ‘Лето’

Практические задачи

Сделайте перечисление с названиями дней недели.

Сделайте перечисление с названиями месяцев.

Перечисления (Enums) — Основы Typescript

В этом уроке мы познакомимся с перечислением. Такая конструкция языка позволяет создать набор имен, а затем обращаться к ним.

Использование перечислений

Перечисления используют вместо строк для постоянных значений:

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' // > 

Открыть доступ

Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно

  • 130 курсов, 2000+ часов теории
  • 1000 практических заданий в браузере
  • 360 000 студентов

Наши выпускники работают в компаниях:

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' // > 

Выводы

В этом уроке мы узнали, для чего и как используется перечисление. Также мы разобрали, что его можно указывать как тип в параметрах функции.

Задание

  1. Реализуйте перечисление ModalStatus с двумя значениями: Opened и Closed
  2. Реализуйте функцию buildModal() . Он возвращает объект, который описывает модальное окно. Параметры функции:
  • Текст, который должен быть внутри окна после инициализации
  • Статус, с которым надо создать объект окна

Функция возвращает объект с двумя полями: text (здесь хранится переданный текст) и status (здесь хранится переданный статус)

const modal = buildModal('hexlet forever', ModalStatus.Opened); //

Упражнение не проходит проверку — что делать? ��

Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:

  • Обязательно приложите вывод тестов, без него практически невозможно понять что не так, даже если вы покажете свой код. Программисты плохо исполняют код в голове, но по полученной ошибке почти всегда понятно, куда смотреть.

В моей среде код работает, а здесь нет ��

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Мой код отличается от решения учителя ��

Это нормально ��, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.

В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Прочитал урок — ничего не понятно ��

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.

Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.

Полезное

Тип enum в JavaScript

Тип enum в JavaScript

Тип enum или по-другому перечисление — это особый тип данных, который позволяет задавать некий список взаимосвязанных констант. Переменные этого типа могут принимать значения только из заданного в перечислении набора. Это свойство перечислений делает их удобным инструментом для реализации списка связанных значений.

Но в JavaScript на текущий момент нет нативной (родной) реализации перечислений. Поэтому давайте посмотрим как мы можем реализовать перечисления на JavaScript самостоятельно.

Начнем с простого:

// задаем некоторое перечисление для тестирования
const color = Colors.RED;

switch(color)
case Colors.RED:
console.log(‘Вы выбрали красный цвет’);
break;

case Colors.GREEN:
console.log(‘Вы выбрали зеленый цвет’);
break;

case Colors.BLUE:
console.log(‘Вы выбрали синий цвет’);
break;

default:
console.log(‘Неизвестный цвет’);
>

Пример выше — самая простая реализация перечисления, во многих случаях ее будет достаточно, но она далека от идеала. Так например, ничего не мешает изменить значение «константы» перечисления на какое-либо другое:

Colors.RED = ‘что то непонятное’ // в перечислении новое значение

Поэтому более правильная реализации перечислений в JavaScript будет иметь следующий вид:

/**
*
* @param obj объект со значениями перечисления
*/
function Enum(obj)
// итоговый объект
const newObj = <>;

// проходимся по каждому свойству переданного в функцию объекта
for( const prop in obj )
// проверяем наличие собственного свойства у объекта
if (obj.hasOwnProperty(prop))

// помещаем в новый объект специальный примитивный тип JavaScript Symbol
newObj[prop] = Symbol(obj[prop]);
>
>

// делаем объект неизменяемым (свойства объекта нельзя будет изменить динамически)
return Object.freeze(newObj);
>

Пример с новой реализацией:

const color = Colors.RED;

console.log(‘color === Colors.RED: ‘, color === Colors.RED) // true
console.log(‘\’red\’ === Colors.RED: ‘, ‘red’ === Colors.RED) // false — строка не равна значению перечисления.
console.log(‘color === Colors.GREEN: ‘, color === Colors.GREEN) // false

Colors.RED = ‘red’; // не меняет значение в перечислении

Как видите новая реализация лучше предыдущей и включает более строгое сравнение типов, которое и требуется от перечислений.

Создано 24.11.2020 14:00:00

  • Михаил Русаков
  • Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

    Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
    Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

    Если Вы не хотите пропустить новые материалы на сайте,
    то Вы можете подписаться на обновления: Подписаться на обновления

    Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

    Порекомендуйте эту статью друзьям:

    Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

    1. Кнопка:
      Она выглядит вот так:
    2. Текстовая ссылка:
      Она выглядит вот так: Как создать свой сайт
    3. BB-код ссылки для форумов (например, можете поставить её в подписи):

    Комментарии ( 0 ):

    Для добавления комментариев надо войти в систему.
    Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.

    Copyright © 2010-2023 Русаков Михаил Юрьевич. Все права защищены.

    Добавить комментарий

    Ваш адрес email не будет опубликован. Обязательные поля помечены *