最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

Typescript 中的 interface 和 type 到底有什么区别详解

来源:懂视网 责编:小采 时间:2020-11-27 21:55:03
文档

Typescript 中的 interface 和 type 到底有什么区别详解

Typescript 中的 interface 和 type 到底有什么区别详解:interface VS type 大家使用 typescript 总会使用到 interface 和 type,官方规范 稍微说了下两者的区别 An interface can be named in an extends or implements clause, but a type alias for an object
推荐度:
导读Typescript 中的 interface 和 type 到底有什么区别详解:interface VS type 大家使用 typescript 总会使用到 interface 和 type,官方规范 稍微说了下两者的区别 An interface can be named in an extends or implements clause, but a type alias for an object

interface VS type

大家使用 typescript 总会使用到 interface 和 type,官方规范 稍微说了下两者的区别

  • An interface can be named in an extends or implements clause, but a type alias for an object type literal cannot.
  • An interface can have multiple merged declarations, but a type alias for an object type literal cannot.
  • 但是没有太具体的例子。

    明人不说暗话,直接上区别。

    相同点

    都可以描述一个对象或者函数

    interface

    interface User {
     name: string
     age: number
    }
    
    interface SetUser {
     (name: string, age: number): void;
    }
    

    type

    type User = {
     name: string
     age: number
    };
    
    type SetUser = (name: string, age: number): void;
    
    

    都允许拓展(extends)

    interface 和 type 都可以拓展,并且两者并不是相互独立的,也就是说 interface 可以 extends type, type 也可以 extends interface 。 虽然效果差不多,但是两者语法不同。

    interface extends interface

    interface Name { 
     name: string; 
    }
    interface User extends Name { 
     age: number; 
    }
    

    type extends type

    type Name = { 
     name: string; 
    }
    type User = Name & { age: number };

    interface extends type

    type Name = { 
     name: string; 
    }
    interface User extends Name { 
     age: number; 
    }
    

    type extends interface

    interface Name { 
     name: string; 
    }
    type User = Name & { 
     age: number; 
    }
    
    

    不同点

    type 可以而 interface 不行

    type 可以声明基本类型别名,联合类型,元组等类型

    // 基本类型别名
    type Name = string
    
    // 联合类型
    interface Dog {
     wong();
    }
    interface Cat {
     miao();
    }
    
    type Pet = Dog | Cat
    
    // 具体定义数组每个位置的类型
    type PetList = [Dog, Pet]
    
    

    type 语句中还可以使用 typeof 获取实例的 类型进行赋值

    // 当你想获取一个变量的类型时,使用 typeof
    let div = document.createElement('div');
    type B = typeof div
    
    

    其他骚操作

    type StringOrNumber = string | number; 
    type Text = string | { text: string }; 
    type NameLookup = Dictionary<string, Person>; 
    type Callback<T> = (data: T) => void; 
    type Pair<T> = [T, T]; 
    type Coordinates = Pair<number>; 
    type Tree<T> = T | { left: Tree<T>, right: Tree<T> };
    

    interface 可以而 type 不行

    interface 能够声明合并

    interface User {
     name: string
     age: number
    }
    
    interface User {
     sex: string
    }
    
    /*
    User 接口为 {
     name: string
     age: number
     sex: string 
    }
    */
    
    

    总结

    一般来说,如果不清楚什么时候用interface/type,能用 interface 实现,就用 interface , 如果不能就用 type 。其他更多详情参看 官方规范文档

    声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文档

    Typescript 中的 interface 和 type 到底有什么区别详解

    Typescript 中的 interface 和 type 到底有什么区别详解:interface VS type 大家使用 typescript 总会使用到 interface 和 type,官方规范 稍微说了下两者的区别 An interface can be named in an extends or implements clause, but a type alias for an object
    推荐度:
    标签: 中的 的区别 type
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top