Sobes.tech
Назад к вопросам
Middle
2

/** * 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; }

Компании, где спрашивали
Altenar

Ответ от нейросети

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 можно расширять путём повторного объявления, что удобно для постепенного добавления свойств.