在TypeScript中,interface(接口)和type(类型别名)都是用于定义类型的关键字,他们之间有一些区别和适用场景。
1.语法差异:
interface使用interface关键字进行定义,而type使用type关键字来进行定义。
2.对象类型VS联合类型:
interface主要用于定义对象类型,可以描述一个对象具有的属性、方法等。而type不仅可以定义对象类型,还可以定义联合类型、交叉类型等更复杂的类型。
3.扩展性:
interface可以通过extends关键字进行扩展,一个接口可以继承另一个接口。而type可以使用交叉类型(&)进行合并,将多个类型合并成一个新的类型。
4.可读性:
interface更常用于描述公共API的形状,因为它们通常更容易解读和理解,而type适用于更复杂的类型和类型别名。
下面是实例代码:
当你需要定义一个对象类型时,比如说一个人的信息,可以使用interface
interface Person{
name:string;
afe:number;
}
const person:Person={
name:'张三',
age:18
}
当你需要使用联合类型或者交叉类型时,比如说定义一个可以接收多种类型的参数,可以使用type
type _obj = {name:'张三'};
type _objs = _obj & {age:18};
function funs(obj:_objs){
const name = obj.name;
const age = obj.age
}