zoukankan      html  css  js  c++  java
  • 聊一下 TS 中的交叉类型

    交叉类型不能完全按照传统编程中的 来理解。

    交叉类型的定义:将多个类型合并为一个类型,包含了所有类型的特性,而且要同时满足要交叉的所有类型。

    后半段话不是很好理解,看一下接口类型和联合类型的交叉类型就好理解了。

    接口类型的交叉类型

    interface Interface1 {
      id: number;
      name: string;
    }
    
    interface Interface2 {
      age: number;
    }
    
    type IntersectionType = Interface1 & Interface2;
    

    交叉类型 IntersectionType 的类型为

    {
    	id: number;
      name: string;
    	age: number;
    }
    

    对于接口类型来说,交叉类型确实是具有所有接口类型的所有特性。

    联合类型的交叉类型

    对于联合类型,情况就有点不同了。

    type UnionA = 'px' | 'em' | 'rem' | '%';
    type UnionB = 'vh' | 'em' | 'rem' | 'pt';
    type IntersectionUnion = UnionA & UnionB;
    

    交叉类型 IntersectionUnion 的类型为:

    'em' | 'rem'
    

    为什么会这样?可以这样来理解。

    交叉类型不仅要将所有的类型合并为一个类型,而且要同时满足要交叉的类型。

    要想同时满足两个接口,那么交叉后的类型必须要同时有那两个接口的属性,否则接口肯定会报需要这个属性,但是没有提供。

    要想同时满足两个联合类型,那么取的必须要是两个联合类型的交集,否则不可能同时满足两个联合类型。

    你还有更好的理解方式吗?欢迎一起交流。

    author: zgc

    -------------------------------------------

    个性签名:梦想不只是梦与想

    如果您觉得这篇文章哪个地方不恰当甚至有错误的话,麻烦告诉一下博主哦,感激不尽。

    如果您觉得这篇文章对你有一点小小的帮助的话,希望能在右下角点个“推荐”哦。

  • 相关阅读:
    Java 理论与实践: 正确使用 Volatile 变量
    Zookeeper 原理
    Java中GC的工作原理
    Redis 5种数据结构使用及注意事项
    Redis 支持的5种数据结构
    浅谈JavaScript词法分析步骤
    四句话总结JavaScript作用域
    Web模板引擎本质前奏
    python【第十三篇】可以写一个堡垒机了
    python【第十二篇下】操作MySQL数据库以及ORM之 sqlalchemy
  • 原文地址:https://www.cnblogs.com/zhangguicheng/p/15733036.html
Copyright © 2011-2022 走看看