前端笔记 - 【TypeScript】 - TS的内置泛型函数【Omit、Pick、Required、Partial】

前言

  • 大家可以结合下面的例子看;

  • 下面的代码就以类型 Person 为例:

    • 以下方式二选一即可;
    ts 复制代码
    type Person = {
        name: string;
        age: number;
        likes?: string[];
        gender: 0 | 1;
    };

一、Omit<T>

  • 作用

    • 一个类型 为 基础 ,支持 剔除 某些类型 ,然后 返回 一个 新类型
    • 简单来说就是,从现有的类型中剔除掉某些属性;
  • 注意

    • 如果想 剔除多个 ,可以使用 联合类型
  • 示例演示:

    ts 复制代码
    // Omit:从现有类型中,剔除某些类型
    
    type Person = {
      name: string;
      age: number;
      likes?: string[];
      gender: 0 | 1;
    };
    
    type OmitPerson = Omit<Person, 'age' | 'likes'>;

二、Pick<T>

  • 作用

    • 类型 的 属性中选取 指定一组 属性 ,然后 返回 一个 新类型
    • 简单来说就是,从现有的类型中,选取指定的类型;
  • 示例演示:

    ts 复制代码
    // Pick:从现有类型中,取出某些属性
    
    interface Person1 {
      name: string;
      age: number;
      likes?: Array<string>;
      gender: 0 | 1;
    }
    
    type PinkPerson1 = Pick<Person1, 'age' | 'name' | 'gender'>;

三、Required<T>

  • 作用

    • 把一个 对象的 属性 转换为 全部必选
  • 示例展示:

    ts 复制代码
    type Person2 = {
        city?: string;
        work?: string;
        salary?: string;
    };
    
    type NewPerson = Person & Person2;
    
    type RequiredPerson = Required<NewPerson>;
    • 得到的新类型 RequiredPerson

四、Partial<T>

  • 作用

    • 把一个 对象的 属性 转换为 全部可选
  • 示例展示:

    ts 复制代码
    // RequiredPerson类型 是 第三节得到的
    
    type PartialPerson = Partial<RequiredPerson>;
    • 得到的新类型 PartialPerson
相关推荐
风止何安啊3 分钟前
一场组件的进化脱口秀——React从 “类” 到 “hooks” 的 “改头换面”
前端·react.js·面试
JS_GGbond4 分钟前
给数组装上超能力:JavaScript数组方法趣味指南
前端·javascript
JQ_Zhang4 分钟前
极致体验!一个小工具实现智能关键词高亮 (中英文混排/全字匹配)
typescript
前端无涯4 分钟前
Tailwind CSS v4 开发 APP 内嵌 H5:安卓 WebView 样式丢失问题解决与降级实战
前端
小邋遢2.06 分钟前
vscod 执行npm build报错:Error: Cannot find module ‘vite‘
前端·npm·node.js
是你的小橘呀7 分钟前
新手入门 React 必备:电影榜单项目核心知识点全解析
前端·javascript
yinmaisoft9 分钟前
JNPF 钉钉双向同步攻略:组织 / 用户一键打通,触发事件自动联动
前端·低代码·钉钉
梨子同志9 分钟前
Node.js Buffer 和 Stream
前端
鹏北海11 分钟前
微信扫码登录 iframe 方案中的状态拦截陷阱
前端·javascript·vue.js
狗哥哥13 分钟前
Vite 插件实战 v2:让 keep-alive 的“组件名”自动长出来
前端·vue.js·架构