typescript中的type关键字和interface关键字区别

Type又叫类型别名(type alias),作用是给一个类型起一个新名字,不仅支持interface定义的对象结构,还支持基本类型、联合类型、交叉类型、元组等任何你需要手写的类型。

TypeScript 复制代码
type num = number; // 基本类型
type stringOrNum = string | number; // 联合类型
type person = {name: string}; // 对象类型
type user = person & { age: number } // 交叉类型
type data = [string, number]; // 元组
type fun = () => void; // 函数类型

type和interface的相同点

1.都可以用来描述一个对象或者函数

interface

TypeScript 复制代码
interface user {name: string; age:number}; // 对象
 
interface setUser {(name: string; age:number):void}; // 函数

type:

TypeScript 复制代码
 type user = {name: string; age:number}; // 对象
 
 type setUser = (name: string; age:number):void;//函数

2.都可以进行拓展

interface可以扩展,type可以通过交叉实现interface的extends行为,interface可以extends type,同时type也可以与interface类型交叉。

TypeScript 复制代码
// interface通过extends实现继承
interface userName {
  name: string;
}
interface user extends userName {
  age: number
}
let stu:user = {name: 'wang', age: 10}


// interface的extends扩展可以通过type交叉(&)类型实现
type userName = {
   name: string;
}
type user = userName & {age: number}
let stu:user={name: 'wang', age: 18}


// interface扩展type
type name = {
  name: string;
}
interface user extends name {
  age: number;
}
let stu:user={name: 'wang', age: 89}


// type与interface交叉
interface name {
  name: string;
}
type user = name & {
  age: number;
}
let stu:user={name:'wang', age: 18}

type和interface的不同点

1.类型别名可以用于其它类型 (联合类型、元组类型、基本类型(原始值)),interface不支持

2.interface 可以多次定义来合并声明,type 不支持

TypeScript 复制代码
interface user {
    name: string;
    age: number;
}
interface user {
    sex: string;
}
//user实际接口为:
{
    name: string;
    age: number;
    sex: string;
}

3.type 能使用 in 关键字生成映射类型,但 interface 不行

TypeScript 复制代码
type keys = 'firstname' | 'surname';
 
type nameTypes = {
  [key in Keys]: string;
};
const test: nameTypes = {
  firstname: 'Pawel',
  surname: 'Grzybek',
};

4.默认导出方式不同

TypeScript 复制代码
// inerface 支持同时声明,默认导出 而type必须先声明后导出
export default interface name {
  name: string;
};

// 同一个js模块只能存在一个默认导出
 type typeName = {name: string};
  export default typeName

5.在type中可以使用泛型

TypeScript 复制代码
type Zoo<T> = T;
const num : Zoo<number> = 3;
 
type callback<T> = (data: T) => void;

6.type可以使用typeof获取实例类型

TypeScript 复制代码
let div = document.createElement('div');
type divType = typeof div;
相关推荐
回忆哆啦没有A梦2 小时前
Vue页面回退刷新问题解决方案:利用pageshow事件实现缓存页面数据重置
前端·vue.js·缓存
A_ugust__3 小时前
vue3+ts 封装跟随弹框组件,支持多种模式【多选,分组,tab等】
前端·javascript·vue.js
林九生3 小时前
【Vue3】v-dialog 中使用 execCommand(‘copy‘) 复制文本失效的原因与解决方案
前端·javascript·vue.js
yi碗汤园3 小时前
【一文了解】C#的StringSplitOptions枚举
开发语言·前端·c#
cxr8285 小时前
BMAD框架实践:掌握story-checklist提升用户故事质量
前端·人工智能·agi·智能体·ai赋能
emma羊羊5 小时前
【xsslabs】第12-19关
前端·javascript·靶场·xss
Larry_Yanan7 小时前
QML学习笔记(十七)QML的属性变更信号
javascript·c++·笔记·qt·学习·ui
真的想不出名儿8 小时前
vue项目引入字体
前端·javascript·vue.js
胡楚昊8 小时前
Polar WEB(1-20)
前端
吃饺子不吃馅8 小时前
AntV X6图编辑器如何实现切换主题
前端·svg·图形学