当前位置 : 主页 > 网络编程 > JavaScript >

TypeScript中的互斥类型实现方法示例

来源:互联网 收集:自由互联 发布时间:2023-01-18
目录 前言 前置知识 对象中多属性同类型的定义 never类型 剔除联合类型中的属性 将对象中的所有属性转为联合类型 实现互斥类型 实现代码 测试用例 用例拆解 写在最后 前言 有这样一
目录
  • 前言
  • 前置知识
    • 对象中多属性同类型的定义
    • never类型
    • 剔除联合类型中的属性
    • 将对象中的所有属性转为联合类型
  • 实现互斥类型
    • 实现代码
    • 测试用例
    • 用例拆解
  • 写在最后

    前言

    有这样一个对象,它有两个属性:name与title,在赋值的时候这两个属性只有一个能出现,例如:name出现的时候title就不能出现,title出现的时候name就不能出现。

    此时,你会怎么用TypeScript来定义这个类型?本文将带大家实现一个互斥类型来解决这个问题,欢迎各位感兴趣的开发者阅读本文。

    前置知识

    在实现之前,我们需要先来了解几个基础的知识。

    对象中多属性同类型的定义

    有一个对象它包含5个可选属性a、b、c、d、e,他们的类型都为string,大多数人的定义方式应该如下所示:

    type obj = {
      a?:string;
      b?:string;
      c?:string;
      d?:string;
      e?:string;
    }

    那么,有没有更好的方式呢

    上一篇:一文带你搞懂JS中六种For循环的使用
    下一篇:没有了
    网友评论