当前位置: 首页 > news >正文

TypeScript回调函数详解

什么是 TypeScript 中的回调函数

callback函数定义为作为参数传递给另一个函数的函数,然后在外部函数内部调用该函数以完成所需的例程或操作。

function outerFunction(callback: () => void) { callback(); }

以下是开发者社区中在 TypeScript 中定义函数回调类型的流行方法。

TypeScript 中回调类型接口的使用

TypeScript 支持通过接口声明来定义变量或函数的通用结构,这种机制特别适用于规范函数的调用签名类型。

让我们考虑以下代码

const greeting = (message:string) => console.log(`Hello ${message}`); interface definitionInterface{ (message:string):void; } function sayHello(callback: definitionInterface) { callback('World!') } sayHello(greeting);

interface定义了definitionInterface的调用签名,其中callback参数类型为字符串,返回类型为 void,表示回调函数的返回值将被忽略。

让我们开始看看回调细节

更改函数签名,即用数字而不是字符串打招呼,将显示类型为字符串不可分配给类型编号的错误。

它创建了一个强大的回调,而不是像我们通常在 JavaScript 中那样传递函数

在 TypeScript 中使用泛型作为回调类型

TypeScript 中的 Generic 允许我们使用如下参数泛化回调。它给你的好处是,每次你需要一个带参数的回调时,一次又一次地用新名称定义一个新接口。

回调在大多数情况下不会返回任何值,因此 typeTwo 类型默认设置为 void。但是如果你想从回调函数返回一个值,你可以指定 typeTwo 类型。

interface callackOneParameter<typeTwo, typeTwo = void> { (param1: typeTwo): typeTwo; }

让我们看看下面两个使用 Generic 接口的示例代码。

interface callBackOneParameter<typeOne, typeTwo =void> { (param1: typeOne): typeTwo; } function greet(message: string) { console.log(`${message}, how are you doing?`) } function sayHello(callback: callBackOneParameter<string>) { callback('Hello') } sayHello(greet)

此代码生成以下结果。

带类型:

interface callBackOneParameter<typeOne, typeTwo =void> { (param1: typeOne): typeTwo; } function greet(message: string) { return `${message}, how are you doing?` } function sayHello(greet: callBackOneParameter<string, string>) { let message = greet('Hi Ibrahim!') console.log(message) } sayHello(greet)

上面的代码生成以下结果

在 TypeScript 中使用 Type 关键字声明回调类型

在 TypeScript 中,type 关键字声明了一个 type 别名。因此,在 type 关键字的帮助下,你可以声明你的回调类型,如下所示。

type callBackFunction = () => void;

这声明了一个不接受任何参数并且不返回任何内容的函数。然后,一个可以接受零到更多任何类型的参数并且不返回任何内容的函数将如下所示。

//Then you can utilize it as let callback: CallbackFunctionVariadic = function(...args: any[]) { // do some stuff };

一个函数可以接受任意数量的参数并返回一个 void 值。

type CallbackFunctionVariadicAnyReturn = (...args: any[]) => any;
http://www.jsqmd.com/news/1098976/

相关文章:

  • 一文读懂工业物联SD-WAN组网:如何破解协议壁垒,及零停机部署实战
  • 第3篇:Context Engineer:构建 AI 的长期记忆与动态知识库
  • 储能 PCS 远程运维怎么做?OTA 升级、固件调试与协议授权的 6 个工程点
  • 终极英雄联盟工具:免费开源LCU API助手完整使用指南
  • 【python】我用AI辅助开发了LanChat 局域网即时通讯的小软件
  • 基于AWS构建Agentic AI智能体:从原理到实战,实现工作流自动化与复利增长
  • 从API报错到本地拦截:电子面单快递公司前置校验改造
  • 3步轻松解密QQ音乐加密音频:qmcdump让你的音乐重获自由
  • SwiftKey整合GPT-4 Turbo:移动端AI输入范式重构
  • FreeRTOS 内核 IPC 通信全家桶——队列、信号量、互斥量、任务通知选型指南
  • VLA-Adapter论文解读(二):三大关键发现
  • 灵衢协议学习——物理层(三)
  • YOLO vs Halcon缺陷检测实战:别被AI焦虑绑架,选对技术才是真本事
  • Advanced XRay技术深度解析:如何通过方块渲染优化实现高效矿石定位
  • 管道泄漏识别 图像数据集 油气泄漏监测 水管泄漏检测图像数据
  • Android 7系统输入(五):应用侧 — InputChannel、ViewRootImpl与事件消费
  • 英雄联盟国服免费换肤终极指南:R3nzSkin完全教程
  • 抖音内容保存终极指南:douyin-downloader让你的收藏变得轻松高效
  • 英伟达“技术没有秘密“合理吗:研发总监拆解护城河的真相
  • 多 Agent 路由设计:当不同渠道、不同用户需要匹配不同“大脑”
  • 智能零售结账系统 文具用品识别数据集 YOLO与OpenCV实现+文具店橡皮+铅笔+尺子识别
  • 链表相关的算法
  • 北京昆仑数智-sql学习笔记
  • 爬虫去重别只会用Set!Python实现亿级数据清洗的4种工业级方案
  • 【VMware OVF导出终极指南】:20年资深架构师亲授5大避坑要点与3种加速导出实战技巧
  • 【数字孪生国标落地第一个月,我给新能源行业测了测段位】
  • 主流开源LLM(Qwen、ChatGLM等)的本地化部署
  • 验厂时,食品工作服需要注意什么?
  • GoalFlow:四、轨迹评分筛选模块(Trajectory Scorer, M3)
  • ps怎么调整图片大小?ps调整图片大小快捷键