Зарегистрируйтесь, чтобы продолжить обучение

Объектные типы Основы Typescript

В этом уроке разберем типы объекта. Они состоят из типов всех входящих в него свойств. Выводятся типы автоматически:

// Тип: { firstName: string, pointsCount: number }
const user = {
  firstName: 'Mike',
  pointsCount: 1000,
}

// Поменять тип свойств нельзя
// Type 'number' is not assignable to type 'string'.
user.firstName = 7

TypeScript не позволяет обращаться к несуществующим свойствам. Это значит, что структура любого объекта должна быть задана при его инициализации:

// Property 'age' does not exist on type '{ firstName: string, pointsCount: number; }'.
user.age = 100

Чтобы принять такой объект в функцию как параметр, нужно указать его структуру в описании функции:

// Свойства в описании типа разделяются через запятую
function doSomething(user: { firstName: string, pointsCount: number }) {
  // ...
}

Теперь внутрь можно передавать любой объект, который совпадает по свойствам:

doSomething({ firstName: 'Alice', pointsCount: 2000 })
doSomething({ firstName: 'Bob', pointsCount: 1800 })

// Так нельзя
doSomething({ firstName: 'Bob' })
// И так тоже
doSomething({ firstName: 'Bob', pointsCount: 1800, key: 'another' })

Как и в случае примитивных типов данных, null и undefined по умолчанию не разрешены. Чтобы изменить это поведение, нужно добавить опциональность:

// firstName может быть undefined
// pointsCount может быть null
function doSomething(user: { firstName?: string, pointsCount: number | null }) {
  // ...
}

Объекты могут быть полезными инструментами при разработке программного обеспечения.

Для полного доступа к курсу нужен базовый план

Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.

Получить доступ
1000
упражнений
2000+
часов теории
3200
тестов

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

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

  • 130 курсов, 2000+ часов теории
  • 1000 практических заданий в браузере
  • 360 000 студентов
Отправляя форму, вы принимаете «Соглашение об обработке персональных данных» и условия «Оферты», а также соглашаетесь с «Условиями использования»

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

Логотип компании Альфа Банк
Логотип компании Aviasales
Логотип компании Yandex
Логотип компании Tinkoff