В этом уроке разберем типы объекта. Они состоят из типов всех входящих в него свойств. Выводятся типы автоматически:
// Тип: { 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 }) {
// ...
}
Объекты могут быть полезными инструментами при разработке программного обеспечения.
Остались вопросы? Задайте их в разделе «Обсуждение»
Вам ответят команда поддержки Хекслета или другие студенты
Для полного доступа к курсу нужен базовый план
Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.