【TS高频面试题】interface与type的区别

2024-09-06 12:44

本文主要是介绍【TS高频面试题】interface与type的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考文章

一、基本概念

1. type(类型别名)

用来给一个类型起新名字,使用 type 创建类型别名。

2. interface(接口)

专门用于定义对象的结构(比如属性和方法)

二、相同点

(1)都可以描述对象或函数

interface

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

type

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

(2)都允许继承

在 TypeScript 中,interface 和 type 可以相互继承。
在 TypeScript 中,interfacetype 可以相互继承,具体如下:

1. interface 可以继承 interface

这是最常见的用法。一个 interface 可以通过 extends 继承另一个 interface

interface Person {name: string;
}interface Employee extends Person {employeeId: number;
}const emp: Employee = {name: "Alice",employeeId: 123
};

2. interface 可以继承 type

interface 也可以通过 extends 继承一个 type,因为 type 也可以定义对象结构。

type Person = {name: string;
};interface Employee extends Person {employeeId: number;
}const emp: Employee = {name: "Bob",employeeId: 456
};

3. type 可以继承 interface

type 可以通过交叉类型(&)继承 interface。交叉类型会将多个类型合并为一个新类型。

interface Person {name: string;
}type Employee = Person & {employeeId: number;
};const emp: Employee = {name: "Charlie",employeeId: 789
};

4. type 可以继承 type

type 可以通过交叉类型继承另一个 type

type Person = {name: string;
};type Employee = Person & {employeeId: number;
};const emp: Employee = {name: "David",employeeId: 101
};
  • interface 可以继承 interfacetype,通过 extends 实现。
  • type 可以继承 interfacetype,通过交叉类型 & 实现。

三、区别

(1) 可声明的类型

type:不仅可以用来表示对象类型,还可以用来表示基本类型联合类型元组和交叉类型

type userName = string;   // 基本类型
type userMsg = string | number;   // 联合类型// 对象类型
type Person = {name: userName;age: number;
};// 使用Person类型
let user: Person = {name: "leo",age: 18
};//  交叉类型 例子:
// 交叉类型将多个类型组合成一个类型,这个类型必须满足所有被组合的类型。对于复杂对象或组合类型的场景非常有用。
type Person = {name: string;age: number;
};type Employee = {employeeId: number;position: string;
};type Developer = Person & Employee; // 交叉类型const dev: Developer = {name: "Alice",age: 28,employeeId: 123,position: "Frontend Developer"
};

interface:仅限于描述对象类型和函数

interface User {name: string;age: number;sayHello: () => void;
}const user1: User = {name: "Alice",age: 25,sayHello: () => console.log("Hello!")
};

(2)interface支持声明合并,type不支持会报错

或者总结成:

  • type 可以做到而 interface 不能做到:可以用来表示基本类型联合类型元组和交叉类型
  • interface 可以做到而 type 不能做到:interface 可以声明合并。如果使用type,就会报 重复定义 的警告
interface test {name: string
}
interface test {age: number
}/*test实际为 {name: stringage: number}
*/

(3)扩展(继承)的的实现方法

interface是通过extends实现的,type是通过&(交叉类型)实现的。

这篇关于【TS高频面试题】interface与type的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1142042

相关文章

HTML5的input标签的`type`属性值详解和代码示例

《HTML5的input标签的`type`属性值详解和代码示例》HTML5的`input`标签提供了多种`type`属性值,用于创建不同类型的输入控件,满足用户输入的多样化需求,从文本输入、密码输入、... 目录一、引言二、文本类输入类型2.1 text2.2 password2.3 textarea(严格

Spring Boot Interceptor的原理、配置、顺序控制及与Filter的关键区别对比分析

《SpringBootInterceptor的原理、配置、顺序控制及与Filter的关键区别对比分析》本文主要介绍了SpringBoot中的拦截器(Interceptor)及其与过滤器(Filt... 目录前言一、核心功能二、拦截器的实现2.1 定义自定义拦截器2.2 注册拦截器三、多拦截器的执行顺序四、过

C# Semaphore与SemaphoreSlim区别小结

《C#Semaphore与SemaphoreSlim区别小结》本文主要介绍了C#Semaphore与SemaphoreSlim区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录一、核心区别概览二、详细对比说明1.跨进程支持2.异步支持(关键区别!)3.性能差异4.API 差

Java中自旋锁与CAS机制的深层关系与区别

《Java中自旋锁与CAS机制的深层关系与区别》CAS算法即比较并替换,是一种实现并发编程时常用到的算法,Java并发包中的很多类都使用了CAS算法,:本文主要介绍Java中自旋锁与CAS机制深层... 目录1. 引言2. 比较并交换 (Compare-and-Swap, CAS) 核心原理2.1 CAS

MySQL中VARCHAR和TEXT的区别小结

《MySQL中VARCHAR和TEXT的区别小结》MySQL中VARCHAR和TEXT用于存储字符串,VARCHAR可变长度存储在行内,适合短文本;TEXT存储在溢出页,适合大文本,下面就来具体的了解... 目录一、VARCHAR 和 TEXT 基本介绍1. VARCHAR2. TEXT二、VARCHAR

python中getsizeof和asizeof的区别小结

《python中getsizeof和asizeof的区别小结》本文详细的介绍了getsizeof和asizeof的区别,这两个函数都用于获取对象的内存占用大小,它们来自不同的库,下面就来详细的介绍一下... 目录sys.getsizeof (python 内置)pympler.asizeof.asizeof

Vue和React受控组件的区别小结

《Vue和React受控组件的区别小结》本文主要介绍了Vue和React受控组件的区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录背景React 的实现vue3 的实现写法一:直接修改事件参数写法二:通过ref引用 DOMVu

Go之errors.New和fmt.Errorf 的区别小结

《Go之errors.New和fmt.Errorf的区别小结》本文主要介绍了Go之errors.New和fmt.Errorf的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考... 目录error的基本用法1. 获取错误信息2. 在条件判断中使用基本区别1.函数签名2.使用场景详细对

Redis中哨兵机制和集群的区别及说明

《Redis中哨兵机制和集群的区别及说明》Redis哨兵通过主从复制实现高可用,适用于中小规模数据;集群采用分布式分片,支持动态扩展,适合大规模数据,哨兵管理简单但扩展性弱,集群性能更强但架构复杂,根... 目录一、架构设计与节点角色1. 哨兵机制(Sentinel)2. 集群(Cluster)二、数据分片

一文带你迅速搞懂路由器/交换机/光猫三者概念区别

《一文带你迅速搞懂路由器/交换机/光猫三者概念区别》讨论网络设备时,常提及路由器、交换机及光猫等词汇,日常生活、工作中,这些设备至关重要,居家上网、企业内部沟通乃至互联网冲浪皆无法脱离其影响力,本文将... 当谈论网络设备时,我们常常会听到路由器、交换机和光猫这几个名词。它们是构建现代网络基础设施的关键组成