Своими словами:
в этих типах мы используем обобщения (дженерики).
Например, утилита
Она берет все ключи исходного типа (
Но к каждому полю добавлен значок
А типы полей ровно те же самые, что и у исходного типа -
В итоге получается точно такая же структура, но каждое поле в ней необязательное.
#typescript
в этих типах мы используем обобщения (дженерики).
Например, утилита
Partial
принимает некий тип T
, неизвестно, какой конкретно, и на его основе создает новый тип.Она берет все ключи исходного типа (
keyof T
) и делает их своими ключами. Каждый конкретный ключ обозначается типом P
. То есть P
- это каждый ключ типа T
, и у нового типа будут те же самые поля.Но к каждому полю добавлен значок
?
- то есть поле становится опциональным, необязательным.А типы полей ровно те же самые, что и у исходного типа -
T[P]
. Это обычный синтаксис доступа к свойствам объекта, но тут он применяется к типу.В итоге получается точно такая же структура, но каждое поле в ней необязательное.
#typescript
👍2🔥1
Typescript. Утилиты. Часть 2 (Exclude, Extract, NonNullable)
Первая часть (Readonly, Required, Partial): https://yangx.top/react_junior/413
Exclude
Принимает два параметра:
-
-
Результатом является объединение, в которое входят все члены
Extract
Принимает два параметра:
-
-
Результатом является объединение, в которое входят все члены
NonNullable
Принимает один параметр
#typescript
Первая часть (Readonly, Required, Partial): https://yangx.top/react_junior/413
Exclude
Принимает два параметра:
-
Union
-
ExcludedMembers
- члены, которые нужно исключить из Union
Результатом является объединение, в которое входят все члены
Union
, кроме тех, которые могут быть присвоены в ExcludedMembers
Extract
Принимает два параметра:
-
Type
-
Union
- объединение типов, которые нужно отобрать из Type
Результатом является объединение, в которое входят все члены
Type
, которые одновременно могут быть присвоены в Union
NonNullable
Принимает один параметр
Type
и выбрасывает из него null
и undefinded
.#typescript
👍2🔥1
Typescript. Утилиты. Часть 3 (Parameters, ReturnType)
Первая часть (Readonly, Required, Partial): https://yangx.top/react_junior/413
Вторая часть (Exclude, Extract, NonNullable): https://yangx.top/react_junior/429
Утилиты
Возьмем функцию:
В утилиту нужно передать тип этой функции, а не ее значение:
Утилита
Утилита
#typescript
Первая часть (Readonly, Required, Partial): https://yangx.top/react_junior/413
Вторая часть (Exclude, Extract, NonNullable): https://yangx.top/react_junior/429
Утилиты
Parameters
и ReturnType
работают с функциями и могут, соответственно, получать типы входных параметров или возвращаемого значения.Возьмем функцию:
function add(num1: number, num2: number): number {
return num1 + num2;
}
В утилиту нужно передать тип этой функции, а не ее значение:
typeof add
Утилита
Parameters
вернет кортеж их типов входных аргументов: [num1: number, num2: number]
Утилита
ReturnType
вернет тип возвращаемого значения:number
#typescript
👍3
TypeScript. Условные типы
Статья (англ): https://javascript.plainenglish.io/use-typescript-conditional-types-like-a-pro-7baea0ad05c5
Утилиты Exclude, Extract, NonNullable, Parameters, and ReturnType используют "условные типы" (Conditional Types).
В статье подробно разбирается их внутреннее устройство, разобравшись с которым можно создавать свои похожие утилиты.
Общий синтаксис условных типов выглядит так:
Берется некий тип
Простейшая утилита
Она просто определяет, является ли переданный тип строкой.
Но можно делать и намного более сложные вещи.
Распределенные условные типы
Если передать в утилиту объединение типов, на выходе тоже можно получить объединение, потому что операция выполняется для каждого члена объединения - это называется _распределенные условные типы__ (distributed conditional type).
Но это работает только для "голых" типов, не обернутых в массивы/кортежи/промисы.
#typescript #ссылки #подкапотом
Статья (англ): https://javascript.plainenglish.io/use-typescript-conditional-types-like-a-pro-7baea0ad05c5
Утилиты Exclude, Extract, NonNullable, Parameters, and ReturnType используют "условные типы" (Conditional Types).
В статье подробно разбирается их внутреннее устройство, разобравшись с которым можно создавать свои похожие утилиты.
Общий синтаксис условных типов выглядит так:
T extends U ? X : Y
Берется некий тип
T
и присваивается типу U
(проверяется, входит ли T
в U
). Если да, возвращается X
, если нет - Y
(X
и Y
могут быть чем угодно, например, тем же исходным типом T
).Простейшая утилита
IsString
такого рода может выглядеть так:T extends string ? true : false
Она просто определяет, является ли переданный тип строкой.
Но можно делать и намного более сложные вещи.
Распределенные условные типы
Если передать в утилиту объединение типов, на выходе тоже можно получить объединение, потому что операция выполняется для каждого члена объединения - это называется _распределенные условные типы__ (distributed conditional type).
Но это работает только для "голых" типов, не обернутых в массивы/кортежи/промисы.
#typescript #ссылки #подкапотом
👍4