/** * Task 1: Generics and Key Type Safety * Create a function `getProperty` that takes an object and a key. * Use generics to ensure the function is type-safe, and the key exists on the object. */ function getProperty<T extends Record<string, unknown>, K extends keyof T>(obj: T, key: K): T[K] { return obj[key]; } getProperty('str', 'toString') /** * Task 2: Given multiple Todo interface declarations below, explain what happens when they are present in the same scope. * Discuss how TypeScript treats them and fill in the `myTodo` object to satisfy the merged Todo interface requirements. */ interface Todo { title: string; dueDate: Date; } interface Todo { description: string; completed: boolean; }
Answer from AI
sobes.tech AI
Задача 1: Функция getProperty использует дженерики и ограничение K extends keyof T, чтобы гарантировать, что ключ key существует в объекте obj типа T. Это обеспечивает типобезопасный доступ к свойствам объекта.
Пример функции:
function getProperty<T extends Record<string, unknown>, K extends keyof T>(obj: T, key: K): T[K] {
return obj[key];
}
const result = getProperty({name: 'Alice', age: 30}, 'name'); // тип string
Вызов getProperty('str', 'toString') корректен, так как у строки есть метод toString.
Задача 2: В TypeScript несколько деклараций интерфейса с одинаковым именем в одной области видимости объединяются (merged). Это значит, что итоговый интерфейс Todo будет содержать все свойства из обеих деклараций:
interface Todo {
title: string;
dueDate: Date;
description: string;
completed: boolean;
}
Чтобы объект myTodo соответствовал объединённому интерфейсу, нужно определить все эти свойства:
const myTodo: Todo = {
title: 'Learn TypeScript',
dueDate: new Date('2024-12-31'),
description: 'Study advanced TypeScript features',
completed: false
};
Таким образом, декларации интерфейсов в TypeScript можно расширять путём повторного объявления, что удобно для постепенного добавления свойств.