在 Angular 中,def interface 和 dto interface 都是 TypeScript 的概念。
def interface(即 default interface)定义了一个基本的数据结构,用于描述一个对象或数据的各个属性和方法。例如:
// 定义 def interface
export default interface Person {
name: string;
age: number;
gender: string;
sayHello: () => void;
}
// 使用 def interface 定义一个对象
const person: Person = {
name: '张三',
age: 25,
gender: '男',
sayHello() {
console.log(`大家好,我是${this.name}`);
}
};
dto interface(即 data transfer object interface)通常用于描述从后端 API 接口返回或发送到后端的数据格式。dto interface 通常不会包含对象的行为方法或方法签名。例如:
// 定义 dto interface
export interface PersonDto {
name?: string;
age?: number;
gender?: string;
}
// 使用 dto interface 定义一个对象
const personDto: PersonDto = {
name: '张三',
age: 25,
gender: '男'
};
在上面的例子中,PersonDto 用于描述从后端 API 接收到的数据格式,可以看到 PersonDto 中的属性都是可选的。
因此,def interface 和 dto interface 的区别在于:def interface 用于描述对象的属性及其行为方法,而 dto interface 用于描述数据的格式。
在使用 Angular 编写前端应用时,我们通常会使用 dto interface 来与后端 API 进行数据交互,以确保数据的格式和类型的一致性。