В этом уроке разберем типы объекта. Они состоят из типов всех входящих в него свойств.
Выводятся типы автоматически:
// Тип: { 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 }) {
// ...
}
Объекты могут быть полезными инструментами при разработке программного обеспечения.
Реализуйте функцию isComplete()
, которая принимает на вход курс и определяет, завершен ли он. Завершенным считается курс, в который добавлено четыре или более уроков:
// Определите тип исходя из структуры объекта
const course = {
name: 'Java',
lessons: ['variables', 'functions', 'conditions'],
};
isComplete(course); // false
Если вы зашли в тупик, то самое время задать вопрос в «Обсуждениях». Как правильно задать вопрос:
Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.
Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи.
В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.
Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в «Обсуждениях». Идеально, если вы сформулируете непонятные моменты в виде вопросов. Обычно нам нужно несколько дней для внесения правок.
Кстати, вы тоже можете участвовать в улучшении курсов: внизу есть ссылка на исходный код уроков, который можно править прямо из браузера.
Ваше упражнение проверяется по этим тестам
1import * as ta from 'type-assertions';
2
3import isComplete from './index';
4
5test('function', () => {
6 const course1 = {
7 name: 'Java',
8 lessons: ['variables', 'functions', 'conditions'],
9 };
10 expect(isComplete(course1)).toBe(false);
11
12 const course2 = {
13 name: 'Java',
14 lessons: ['variables', 'functions', 'conditions', 'loops'],
15 };
16 expect(isComplete(course2)).toBe(true);
17
18 const course3 = {
19 name: 'Java',
20 lessons: ['variables', 'functions', 'conditions', 'loops', 'cringe'],
21 };
22 expect(isComplete(course3)).toBe(true);
23
24 ta.assert<ta.Equal<ReturnType<typeof isComplete>, boolean>>();
25 ta.assert<ta.Equal<Parameters<typeof isComplete>[0], { name: string, lessons: string[] }>>();
26});
27
Решение учителя откроется через: