博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[TypeScript] Transform Existing Types Using Mapped Types in TypeScript
阅读量:6583 次
发布时间:2019-06-24

本文共 2304 字,大约阅读时间需要 7 分钟。

Mapped types are a powerful and unique feature of TypeScript's type system. They allow you to create a new type by transforming all properties of an existing type according to a given transformation function. In this lesson, we'll cover mapped types like Readonly<T> or Partial<T> that ship with the TypeScript compiler, and we'll also explore how to create our own type transformations.

 

There are few mapped types built-in:

/** * Make all properties in T optional */type Partial
= { [P in keyof T]?: T[P];};/** * Make all properties in T readonly */type Readonly
= { readonly [P in keyof T]: T[P];};/** * From T pick a set of properties K */type Pick
= { [P in K]: T[P];};/** * Construct a type with a set of properties K of type T */type Record
= { [P in K]: T;};

 

Take readonly as an example, the output is like this:

interface Point {

   x: number;
   y: number;
}

ReadonlyPoint = Readonly
; type ReadonlyPoint = { readonly x: number; readonly y: number;}

So for each props in Point, we append 'readonly' type for it.

 

The way type resolve:

interface Point {    x: number;    y: number;}// Fromtype ReadonlyPoint = {    readonly [P in keyof Point]: Point[P]}type ReadonlyPoint = {    readonly [P in "x" | "y"]: Point[P]}type ReadonlyPoint = {    readonly x: Point["x"];    readonly y: Point["y"];}// Totype ReadonlyPoint = {    readonly x: number    readonly y: number;}

 

The same process can be done with Partial type:

type PartialPoint = Partial
;// Fromtype PartialPoint = { [P in keyof T]?: T[P];}type PartialPoint = { [P in keyof Point]?: Point[P];}type PartialPoint = { [P in "x" | "y"]?: Point[P];}type PartialPoint = { x?: Point["x"]; y?: Point["y"];}// Totype PartialPoint = { x?: number; y?: number;}

 

We can also write Nullable type by ourselves:

type Nullable
= { [P in keyof T]: T[P] | null}

For each Prop fo Type T, it can be its value or null.

 

We can also combine different type together:

type Nullable
= { [P in keyof T]: T[P] | null}type Stringify
= { [P in keyof T]: string}type NullablePoint = Nullable
type PartialNullablePoint = Partial
>>

 

转载地址:http://rwino.baihongyu.com/

你可能感兴趣的文章
下拉菜单
查看>>
[清华集训2014]玛里苟斯
查看>>
【MVC+EasyUI实例】对数据网格的增删改查(上)
查看>>
Project Euler 345: Matrix Sum
查看>>
你可能不知道的技术细节:存储过程参数传递的影响
查看>>
[摘录]调动员工积极性的七个关键
查看>>
.htaccess 基础教程(四)Apache RewriteCond 规则参数
查看>>
UVM中的class--2
查看>>
ORACLE 存储过程异常捕获并抛出
查看>>
root用户重置其他密码
查看>>
Oracle推断值为非数字
查看>>
多年前写的一个ASP.NET网站管理系统,到现在有些公司在用
查看>>
vue-cli中理不清的assetsSubDirectory 和 assetsPublicPath
查看>>
从JDK源码角度看Short
查看>>
五年 Web 开发者 star 的 github 整理说明
查看>>
Docker 部署 SpringBoot 项目整合 Redis 镜像做访问计数Demo
查看>>
中台之上(五):业务架构和中台的难点,都是需要反复锤炼出标准模型
查看>>
inno setup 打包脚本学习
查看>>
php 并发控制中的独占锁
查看>>
React Native 0.20官方入门教程
查看>>