ts的接口介绍和使用

简言

了解下ts接口(interface)的作用和使用方式。

接口

介绍

在TypeScript里,接口的作用就是为你的代码或第三方代码做类型声明,是命名对象类型的一种方式。

使用关键字:interface 定义。

ts的接口需要以定义(限制)的角度来理解,只要传入的对象满足接口提到的必要条件,那么它就是被允许的。

还有一点值得提的是,类型检查器不会去检查属性的顺序,只要相应的属性存在并且类型也是对的就可以。

typescript 复制代码
//  接口
interface LabelledValue {
  label: string;
}

//  参数使用接口
function printLabel(labelledObj: LabelledValue) {
  console.log(labelledObj.label);
}

let myObj = {
  label: "Size 10 Object",
  size: 10,
  run: () => {
    console.log(this.size);
  }
};
printLabel(myObj);

可选属性

语法: 定义属性时,冒号前面加?,例如:interface A {a?:string}

接口里的属性不全都是必需的。 有些是只在某些条件下存在,或者根本不存在。 可选属性在应用"option bags"模式时很常用,即给函数传入的参数对象中只有部分属性赋值了。

typescript 复制代码
interface Options {
  a: number,
  b?: number, //  可选属性b
}

function run(options: Options): boolean {
  const { a, b } = options
  console.log(a);
  console.log(b);
  //  b是可选属性,使用时加判断
  if (b)
    return a > b
  else
    return true
}

run({ a: 10 })

只读属性

语法: 定义属性时, 属性前加readonly,代表这个是只读属性。例如:interface A { readonly a:number }

一些对象属性只能在对象刚刚创建的时候修改其值。 你可以在属性名前用 readonly来指定只读属性.

可合并

interface声明的对象类型允许合并。不过,如果是含有同名属性,它的类型要保持一致。

可继承

interface声明的对象类型可以继承其他接口对象类型,使用extends扩展。

结语

interface是一个使用率非常高的声明对象类型的方式。

相关推荐
VillenK2 小时前
版本依赖问题:vite-plugin-dts@3.1.0 与 jiti 的兼容性
前端·typescript·vite
轻口味4 小时前
AI 时代全栈开发破局:TypeScript 生态实战,从入门到部署一站式通关
前端·mongodb·docker·ai·typescript·react·next.js
Czzzzlq7 小时前
【无标题】
typescript·node.js·ai编程
mobº9 小时前
Vue3 +TypeScript 项目总结
前端·javascript·typescript
用户056694948311 天前
🔥 我把 axios 接口封装,玩出了 NestJS 的感觉
typescript
索西引擎1 天前
【理论】TypeScript 函数重载:从 Vue 3 defineEmits 说起的类型安全实践
前端·typescript
漫游的渔夫1 天前
从 if-else 乱麻到状态机:前端开发者该怎么理解多 Agent 协作?
前端·人工智能·typescript
matrixmind81 天前
sindresorhustype-fest:TypeScript 工具类型集合
前端·javascript·其他·typescript
guangzan2 天前
DeepSeek-Lane:在 Cursor 内使用 DeepSeek V4 模型
typescript
晓杰'2 天前
从0到1实现 Balatro 游戏后端(1):项目规划与牌型判断实现
后端·websocket·typescript·node.js·游戏开发·项目实战·nestjs