前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >TS高级类型

TS高级类型

作者头像
贺贺V5
发布2023-02-14 19:25:40
6810
发布2023-02-14 19:25:40
举报

keyof

获取类型内所有的 key,即所有属性名 , 获取的是一个 联合类型 这里类型指:通过 interface 或 type 定义的类型;通过 typeof xxx 返回的类型等。keyof 后面必须是类型,不能是具体的对象

代码语言:javascript
复制
interface IPeople {
    name:string,
    age?: number,
    sex: string,
  }
  
  type T = keyof IPeople

  // 等同于
  type T = "name" | "age" | "sex"

in

循环类型 一般循环的是 联合类型,把联合类型中每一个属性名赋值给 P

代码语言:javascript
复制
// 使用上面的 T 类型
  type TObj =  {
    [P in keyof T]: any
  }

  // 等同于
  type TObj = {
    name: any;
    age: any;
    sex: any;
  }

typeof

ts 中 typeof 是获取数据的类型,常用用于获取 对象、数组、函数、class、枚举等类型

代码语言:javascript
复制
const people = {
    name: 'liuyz',
    age: 18,
  }
  
  type INewPeople = typeof people
  // 等同于
  // type INewPeople = {
  //   name: number
  //   age: number
  // }
  
  const newPeople: INewPeople = {
    name: "zhi",
    age: 18,
  }
  
  type TKeys = keyof typeof newPeople
  // 等同于
  // type TKeys = "name" | "age"

Pick

从 T 类型中选取部分 K 类型,并返回新的类型,这里 T 常用于对象类型

代码语言:javascript
复制
 type Pick<T, K extends keyof T> = {
      [P in K]: T[P];
  };
// keyof T 获取 T 中所有的 key 属性
//K extends keyof T K 必须继承于 keyof T ,如果 K 中的属性有不属于 keyof T 的则会报错
interface IPeople {
    name:string,
    age?: number,
    sex: string,
  }
  
  type TPick = Pick<IPeople, 'name' | 'age'>
  
  // 等同于
  type TPick = {
    name: string;
    age?: number | ?developer/article/2216963/undefined;
  }

Partial

将T中的所有属性设置为可选

代码语言:javascript
复制
type Partial<T> = {
      [P in keyof T]?: T[P];
  };
interface IPeople {
    name:string,
    age?: number,
    sex: string,
  }
  type TPartial = Partial<IPeople>
  
  // 等同于
  type TPartial = {
    name?: string | ?developer/article/2216963/undefined;
    age?: number | ?developer/article/2216963/undefined;
    sex?: string | ?developer/article/2216963/undefined;
  }

Required

使 T 中的所有属性都变成必需的

代码语言:javascript
复制
interface IPeople {
    name:string,
    age?: number,
    sex: string,
  }
  type TRequired = Required<IPeople>

  // 等同于
  type TRequired = {
    name: string;
    age: number;
    sex: string;
  }

Readonly

将 T 中的所有属性设为只读

代码语言:javascript
复制
<!-- 源码 -->
  type Readonly<T> = {
    readonly [P in keyof T]: T[P];
  }

 interface IPeople {
    name:string,
    age?: number,
    sex: string,
  }
  type TReadonly = Readonly<IPeople>

  // 等同于
  type TReadonly = {
     readonly name: string;
     readonly age?: number | ?developer/article/2216963/undefined;
     readonly sex: string;
  }

Exclude

从T中剔除可以赋值给U的类型

Extract

提取T中可以赋值给U的类型

Omit

代码语言:javascript
复制
// 就是在 User 的基础上,去掉 id 属性
type EditUser = Omit<User,"id">; 

Pick

从类型定义的属性中,选取指定一组属性,返回一个新的类型定义。

代码语言:javascript
复制
type Pick<T, K extends keyof T> = {
  [P in K]: T[P];
};

NonNullable

去除 null 和 ?developer/article/2216963/undefined 后的新类型

代码语言:javascript
复制
type TType= number | null | ?developer/article/2216963/undefined
  type TNonNullable = NonNullable<TType>
  // 等同于
  // type TNonNullable = number

typeof

  • 自动生成对象的类型,如果对象上有类型则使用定义的类型
本文参与?腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-01-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客?前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与?腾讯云自媒体分享计划? ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • keyof
  • in
    • typeof
    • Pick
    • Partial
    • Required
    • Readonly
    • Exclude
    • Extract
    • Omit
    • Pick
    • NonNullable
    • typeof
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
    http://www.vxiaotou.com