首页 > 移动平台 > 详细

[TypeScript] Create Explicit and Readable Type Declarations with TypeScript mapped Type Modifiers

时间:2019-01-17 20:49:18      阅读:180      评论:0      收藏:0      [点我收藏+]

Using the optional “+” sign together with mapped type modifiers, we can create more explicit and readable type declarations. We can also use the “-” (minus) sign to remove optional declarations from properties.

 

For example, we have an interface:

interface IPet { 
    name: string;
    age: number;
    favoritePark?: string
}

There is two required props and one favoriatePark as optional prop.

 

From TypeScirpt 2.8, we are able to gereate a new interface based on existing one, and add or remove props:

For example we want to remove all the optional props, we can use ‘-‘:

interface IPetRequired {
  [K in keyof IPET]-?: IPet[K]
}

‘-‘: remove

‘?‘: optional

‘-?‘: remove optional

 

We can also use ‘+‘ to indicate what we have added:

type ReadonlyPet = {
    +readonly [K in keyof IPet]?: IPet[K]
}

Here we added readonly type.

[TypeScript] Create Explicit and Readable Type Declarations with TypeScript mapped Type Modifiers

原文:https://www.cnblogs.com/Answer1215/p/10284223.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!