一、接口基础概念

        接口(interface)是 TypeScript 的核心类型系统工具,用于定义对象的结构规范。它不关心具体实现细节,只强制要求符合接口定义的对象必须包含指定属性和方法。例如:

interface Person {name: string;age: number;greet(): void;
}

二、核心用法与 API

1.对象类型约束

最基础用法是声明对象形状:

interface User {id: number;username: string;
}
const admin: User = { id: 1, username: "admin" }; // ✅ 符合接口

2.可选属性

通过 ? 声明非必需属性:

interface Config {url: string;timeout?: number; // 可选
}

3.只读属性

readonly 防止修改:

interface Point {readonly x: number;readonly y: number;
}

4.函数类型

定义函数签名:

interface SearchFunc {(source: string, keyword: string): boolean;
}
const mySearch: SearchFunc = (src, kw) => src.includes(kw);

5.索引类型

支持动态键值对(数字/字符串索引):

// 数字索引
interface NumMap {[index: number]: string;
}
const arr: NumMap = ["TS", "JS"]; // arr[0]="TS"// 字符串索引
interface StrMap {[key: string]: number;
}
const dict: StrMap = { "A": 65, "B": 66 }; // dict["A"]=65

6.类实现接口

强制类满足特定契约(面向对象):

interface ClockInterface {currentTime: Date;setTime(d: Date): void;
}class Clock implements ClockInterface {currentTime: Date = new Date();setTime(d: Date) { this.currentTime = d; }
}

7.接口继承

支持单继承或多继承:

interface Shape { color: string; }
interface Circle extends Shape { radius: number; }const c: Circle = { color: "red", radius: 10 }; // ✅

8.接口合并

同名接口自动合并(扩展第三方库常用):

interface Box { width: number; }
interface Box { height: number; }
// 合并后: { width: number; height: number; }

三、接口 vs 类型别名(type)

特性interfacetype
扩展方式继承(extends交叉类型(&
合并同名声明✅ 自动合并❌ 报错
函数/元组定义✅ 支持✅ 支持
声明合并
实现类✅ implements❌ 仅对象类型

最佳实践:优先使用 interface 定义对象结构,用 type 处理联合类型或复杂类型运算。

四、高级技巧

1.混合类型

组合函数和对象属性:

interface Counter {(start: number): void;interval: number;reset(): void;
}

2.索引签名约束

限制索引值类型必须匹配特定属性:

interface Foo {[key: string]: number;bar: number; // ✅// baz: string; ❌ 违反索引签名
}

五、常见错误解决方案

  1. 属性缺失错误 → 检查是否遗漏必需属性或误用可选属性

  2. 类型不匹配错误 → 确认属性类型是否精确符合接口定义

  3. 索引签名冲突 → 确保所有显式属性符合索引签名类型

接口的核心价值在于 定义契约 而非实现,这是构建可维护大型项目的关键。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/bicheng/94188.shtml
繁体地址,请注明出处:http://hk.pswp.cn/bicheng/94188.shtml
英文地址,请注明出处:http://en.pswp.cn/bicheng/94188.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

selenium3.141.0执行JS无法传递element解决方法

问题:在Chrome 131版本以下执行下面代码没有问题,但是在131版本以上出现element无法传递问题,执行下面代码会出现 "Message: javascript error: Cannot read properties of undefined (reading click)"# xpath匹配元素,…

汽车主机厂为何开始押注平台化视觉?

近年来,随着智能制造、出口质量标准、新能源整车结构复杂度等多重因素叠加,越来越多主机厂开始从“点状部署”转向“系统化导入”,平台化的AI视觉检测体系正逐步成为整车厂的标准化选项。在过去,汽车制造四大车间——焊装、涂装、…

STM32 - Embedded IDE - GCC - 重定向printf到串口

导言如上所示,在不同的编译器下,重定向printf到串口时,使用的函数不一样。 ARMCC(Keil-MDK)使用fputc()GCC使用_write() 总之,GCC/newlib的printf()走_write(),不是fputc()。

51单片机-中断系统

本质概述思维导图:51单片机中断系统中断系统概述中断系统是为使CPU具有对外界紧急事件的实时处理能力而设置的。当中央处理机CPU正在处理某件事的时候外界发生了紧急事件请求,要求CPU暂停当前的工作,转而去处理这个紧急事件,处理完…

ubuntu - 终端工具 KConsole安装

地址: https://konsole.kde.org/download.html 直接使用自带安装管理器安装即可

QT-左右侧边栏动画

QT-左右侧边栏动画演示效果一、核心程序二、链接演示效果 一、核心程序 #ifndef SLIDEPANEL_H #define SLIDEPANEL_H#include <QWidget> #include <QPropertyAnimation> #include <QPushButton> #include <QVBoxLayout>class SlidePanel : public QWi…

WebRTC 结合云手机:释放实时通信与虚拟手机的强大协同效能

开发一个基于 WebRTC 技术的云手机群控系统&#xff0c;实现通过浏览器远程控制多台云手机&#xff0c;并提供文件管理、代理管理、备份管理等功能。这里只详细分享 WebRTC 技术。 https://github.com/LingyuCoder?tabrepositories&qsky&type&language&sort …

Kafka中zk的作用是什么

Zookeeper是分布式协调&#xff0c;注意它不是数据库 kafka中使用了zookeeper的分布式锁和分布式配置及统一命名的分布式协调解决方案 在kafka的broker集群中的controller的选择&#xff0c;是通过zk的临时节点争抢获得的 brokerID等如果自增的话也是通过zk的节点version实现的…

【lucene】lucene常用查询一览

Lucene 里除了常见的 **TermQuery / BooleanQuery / PhraseQuery / FuzzyQuery / SpanNearQuery** 之外&#xff0c;还有不少“特殊家族”。下面按“族”归纳&#xff0c;一眼就能知道它们各自解决什么问题、跟普通倒排检索的差别在哪。────────────────── …

base64认识实际使用

Base64是网络上最常见的用于传输8Bit字节码的编码方式之一&#xff0c;Base64就是一种基于64个可打印字符来表示二进制数据的方法。 Base64&#xff0c;就是包括小写字母a-z、大写字母A-Z、数字0-9、符号"“、”/"一共64个字符的字符集&#xff0c;&#xff08;任何…

LX8201微孔雾化驱动芯片应用笔记一DC5V供电

前言LX8201是深圳市乐⽽信科技服务有限公司最新⾃研的⼀款微孔雾化⽚专⽤驱动芯⽚&#xff0c;结合标准外围电路&#xff0c;能有效驱动控制市⾯上各种微孔雾化⽚&#xff0c;基于独特的电路设计和软件算法&#xff0c;其在功耗以及成本上均具有明显的优势。本应用笔记将帮助用…

MySQL索引优化之索引条件字段类型不同

在sql的联表查询中&#xff0c;on后面相等的两个字段如果字段类型不一致&#xff0c;尽管它们都加了索引&#xff0c;最终查询的时候也不会走索引&#xff0c;这是因为会触发隐式类型转换导致索引失效。 例如 Select * from Orders o left join User u on o.user_id u.id; 假如…

【Linux】信号(二):Linux原生线程库相关接口

【Linux】信号的控制使用一.线程的创建pthread_create()接口二.线程等待1.为什么要线程等待&#xff1f;2.pthread_join()三.线程中止1.return2.pthread_exit五.线程应用C自带多线程在上次的博客中主要讲解了什么是线程 这次的博客主要是带大家把线程的相关接口简单的使用一下 …

小程序被爬虫攻击,使用waf能防护吗?

在移动互联网时代&#xff0c;小程序以轻量化、高便捷性成为流量入口新宠&#xff0c;但也因此成为爬虫攻击的重灾区。从电商平台的价格数据爬取到内容平台的版权盗用&#xff0c;爬虫攻击不仅消耗服务器资源&#xff0c;更可能导致商业机密泄露与用户权益受损。面对这类威胁&a…

通过自动化本地计算磁盘与块存储卷加密保护数据安全

作为打造开发者首选云平台使命的一部分&#xff0c;我们持续推出免费的智能化功能与产品来加强云资源安全。最新推出的本地磁盘加密功能是我们正在所有核心计算区域逐步部署的最新计算特性。当您在首选区域启用本地磁盘加密功能后&#xff0c;新部署的计算实例将默认自动启用数…

中文房间悖论:人工智能理解力的哲学拷问

本文由「大千AI助手」原创发布&#xff0c;专注用真话讲AI&#xff0c;回归技术本质。拒绝神话或妖魔化。搜索「大千AI助手」关注我&#xff0c;一起撕掉过度包装&#xff0c;学习真实的AI技术&#xff01;1 思想实验阐述中文房间&#xff08;Chinese Room&#xff09;思想实验…

mac如何运行windows程序?性能党vs便捷党选择指南

macOS的流畅稳定虽让人青睐&#xff0c;但系统的不兼容性是个大问题。有的用户想要使用某个专业程序&#xff0c;发现只有Windows版本&#xff0c;然而没法直接在mac上运行&#xff0c;非常懊恼&#xff01;mac如何运行windows程序&#xff1f;本文将提供多个可行的方法&#x…

设置电机数据(闭环驱动器C5-E) ——易格斯igus

4.3 设置电机数据 在调试之前&#xff0c;电机控制器需要电机数据表中的一些值。 ■ 极对数&#xff1a;对象 2030h&#xff1a;00h&#xff08;极对数&#xff09; 电机极对数应在此处输入。对于步进电机&#xff0c;极对数使用步距角计算&#xff0c;例如&#xff0c;1.8 …

药品追溯码(溯源码)采集系统(二):门诊发药后端

门诊发退药追溯码采集系统解析&#xff1a;一、门诊发退药追溯码数据表1.1、Wm_ware_dispense_bill表&#xff1a;该表用于存储处方信息1.2 Wm_ware_dispense_tracecode:追溯码采集表二、发退药后端代码后端代码基于Springboot架构和mybatis-plus&#xff0c;先看主要接口信息&…

Unity编辑器相关

前言继承EditorWindow。 GUILayout类与EditorGUILayout类的应用区别&#xff1a;//TODO创建窗口的方法1&#xff09;GetWindow<T>() 已开则聚焦、未开则创建。无需再手动调用 Show()。GetWindow<T>() 提供多个重载。2&#xff09;CreateInstance<T>()始终创建…