TS中获取函数的参数类型、函数的返回值类型、构造函数的参数类型

背景:通常在业务中我们需要封装一些公共函数或者引入第三方库的函数、类,在TS语法环境下,如何在调用函数处给定义的变量进行类型定义?是需要全局定义变量类型亦或是各自定义?当然都不需要,我们可以通过ts中给出的关键词来获取相关参数。

一、获取函数参数的类型——Parameters

例如封装了一个请求函数:

type LoginType = {account: string,password: string
}
type LoginRespType = {access_token: string
}
export const Login = (data: LoginType, loading: boolean) => {// 通过泛型传给封装的request中定义返回类型return request<LoginRespType>({method: "post",data})
}

在调用处:

import {Login} from "./api.ts"const handleLogin = () => {// 加上typeof获取函数的类型,得到一个元组[LoginType, boolean]let params: Parameters<typeof Login>[0];// 添加参数...Login(params)
}

二、获取函数返回类型——ReturnType

接上一个例子,我们可以在调用Login函数的地方获取返回类型:

import {Login} from "./api.ts"const handleLogin = async () => {const params: Parameters<typeof Login>;// 添加参数...// 获取到Login函数的返回类型 LoginRespTypeconst res: ReturnType<typeof Login> = await Login(params)// res. 可以获取到access_token
}

三、获取构造函数的参数类型——ConstructorParameters

class Socket {constructor(wsUrl: string) {// ...}
}
// 获取构造函数参数的类型,获取到元组 [string]
const wsUrl: ConstructorParameters<typeof Socket>[0] = "";
const ws = new Socket(wsUrl);

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

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

相关文章

整理好了!2024年最常见 20 道设计模式面试题(十)

上一篇地址&#xff1a;整理好了&#xff01;2024年最常见 20 道设计模式面试题&#xff08;九&#xff09;-CSDN博客 十九、访问者模式是如何分离算法与操作对象的&#xff1f; 访问者模式&#xff08;Visitor Pattern&#xff09;是一种行为型设计模式&#xff0c;它允许我…

Python中文自然语言处理(NLP)中文分词工具库之pkuseg使用详解

概要 在中文自然语言处理(NLP)中,分词是一个基础且关键的任务。pkuseg 是由北京大学开发的一个中文分词工具,专为处理现代汉语而设计。它采用了先进的深度学习技术,能够准确地进行中文分词,同时支持自定义词典和多领域分词。本文将详细介绍 pkuseg 库,包括其安装方法、…

《图数据库:理论与实践》书籍销售火爆,二次印刷重磅来袭!

好书共享&#xff0c;就在此刻&#xff01; 由创邻科技联合电子工业出版社匠心打磨三年&#xff0c;最终成稿的图数据库书籍《图数据库&#xff1a;理论与实践》发行上线后&#xff0c;获得了广泛好评&#xff0c;各平台销量迅速破千&#xff0c;并荣登京东 “数据库图书榜”热…

给PDF添加书签的通解-姜萍同款《偏微分方程》改造手记

背景 网上找了一本姜萍同款的《偏微分方程》&#xff0c;埃文斯&#xff0c;英文版&#xff0c;可惜没有书签&#xff0c;洋洋七百多页&#xff0c;没有书签&#xff0c;怎么读&#xff1f;用福昕编辑器自然能手工一个个加上&#xff0c;可是劳神费力&#xff0c;非程序员所为…

Spock使用Spy来Mock内部调用的方法

使用Spy来Mock内部调用的方法 如果使用Spy不生效参考 使用前先看看哪些场景不生效,避免浪费太多时间,我曾经就是mock一个方法折腾两个小时都没弄出来,后来问了 小美智能助理 ,告诉我其中private修饰的方法不生效..我把private改成protected​ 修饰之后, 再次重启单测,立马就好…

【Nprogress】页面跳转进度条

【Nprogress】页面跳转进度条 介绍安装引入并简单使用基本用法配置项常用方法 参考文档&#xff1a; 【博主&#xff1a;码农键盘上的梦】vue使用Nprogress进度条功能实现 【博主&#xff1a;夜幕506】vue项目的进度条插件 – nprogress 【官方项目地址】https://www.npmjs.com…

Spring Boot高级配置与自定义Starter详解

介绍 Spring Boot是一个用于简化Spring应用开发的框架&#xff0c;它通过提供一系列的默认配置和自动化的功能&#xff0c;极大地降低了项目的复杂度和开发成本。本文将深入探讨Spring Boot的高级配置和自定义Starter的实现&#xff0c;帮助开发者更好地理解和应用这些特性。 …

【C语言】数据的存储

本章重点 1. 数据类型详细介绍 2. 整形在内存中的存储&#xff1a;原码、反码、补码 3. 大小端字节序介绍及判断 4. 浮点型在内存中的存储解析 Ⅰ、数据类型介绍 前面我们已经学习了基本的内置类型&#xff1a; 空间大小&#xff08;字节&#xff09; char //字…

别只看影响因子了!又1本毕业神刊偷偷被On Hold了!请谨慎投递

【SciencePub学术】昨日&#xff0c;2023JCR正式发布&#xff0c;现在影响因子的话题依旧是“热搜第一”。大家可以根据自己的研究方向&#xff0c;参考最新发布的JCR报告进行投稿选刊。若大家对于投稿选刊方面有任何问题&#xff0c;都可联系张老师为您解答&#xff01; 相关…

C++之STL(四)

1、迭代器 通过重载*、->、、--等运算符来支持指针操作。 迭代器是容器与算法的桥梁。 2、迭代器的类型 个人理解&#xff0c;迭代器是一个模板类&#xff0c;会根据你传入的类型&#xff0c;生成对应的类型。这个模板类里面存放这该类型的指针&#xff0c;里面重载了*、!…

Boom 3D软件安装包下载-Boom 3D官网最新版下载

众多使用者向我们证明了Boom3D软件31段均衡器和预设&#xff1a;均衡器允许您仅通过手指滑动来调制音频&#xff0c;并将其另存为自定义预设&#xff0c;预设已经精心设计为不同类型的歌曲&#xff0c;因此您能够简单地拨入音频以适应您的心情。相信大家都认同Boom 3D 是一款出…

189.二叉树:将有序数组转换为二叉搜索树(力扣)

代码解决 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), right(nullptr) {}* TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}* Tre…

华为移动网络自动驾驶解决方案MAE和无线解决方案云的开发技术方案

华为移动网络自动驾驶解决方案MAE和无线解决方案云的开发技术方案 目录 引言华为移动网络自动驾驶解决方案MAE 2.1 概述2.2 关键技术2.3 架构设计2.4 典型应用场景2.5 开发工具和环境 华为无线解决方案云 3.1 概述3.2 关键技术3.3 架构设计3.4 典型应用场景3.5 开发工具和环境…

AI选美大赛揭晓10位入围AI佳丽

全球首届AI小姐选美大赛&#xff08;WAICAs&#xff09;于上月拉开帷幕&#xff0c;总奖池积累到1.6万英镑&#xff0c;1万余名AI创作者参与&#xff0c;报送了超过1500个AI角色参加这场比赛。WAICAs 全称是未来派世界人工智能创造者大奖&#xff0c;由 Fanvue 主办。日前&…

qt打包失败 ,应用程序无法正常启动0xc000007b解决办法

用 windeployqt 打包QT程序&#xff0c;运行时提示程序无法正常启动0xc000007b #原因&#xff1a;因本机装了多个版本的Qt&#xff0c;包括32位&#xff0c;64位的&#xff0c;在cmd下可能是环境变量原因&#xff0c;用 windeployqt 打的包无法运行 解决办法&#xff1a; 1、…

以餐厅为例,来谈谈VOC(客户之声)

VOC&#xff0c;即客户之声&#xff0c;是指通过收集和分析客户的反馈意见&#xff0c;了解他们的需求和期望&#xff0c;进而指导企业改进产品和服务。在餐厅经营中&#xff0c;VOC的应用不仅能够帮助餐厅了解顾客的口味偏好、用餐习惯&#xff0c;还能揭示服务流程中的不足和…

记录一个因 MYSQL 服务端和JDBC驱动版本不一致导致 HMS 启动失败问题

记录一个因 MYSQL 服务端和JDBC驱动版本不一致导致 HMS 启动失败问题 1. 问题现象 某运维同学安装 CDH 后 HIVE 服务报警&#xff0c;查看发现 HS2 的金丝雀检查失败&#xff0c;进一步查看发现&#xff0c;HS2 无法创建默认数据库&#xff0c;且 HMS 启动失败。遂找到笔者进…

MATLAB——数组类型(二)

文章目录 前言元胞数组元胞数组寻访元胞数组的操作合并删除变形 前言 本章记录一下元胞数组的相关操作。寻访、合并、删除、变形。 元胞数组 元胞数组概念及创建详见MATLAB——数组类型。 元胞数组寻访 元胞数组中单元与单元内容是两个不同的东西。因此寻访单元和寻访单元…

vue3中如何使用pinia -- pinia使用教程(一)

vue3中如何使用pinia -- pinia使用教程&#xff08;一&#xff09; 安装使用创建 store使用 store访问修改 store 使用组合式 api 创建 store -- setup storepinia 和 hook 的完美结合如何解决上面的问题 使用 hook 管理全局状态和 pinia 有何优缺点&#xff1f;参考小结 pinia…

上位机图像处理和嵌入式模块部署(mcu之iap升级)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 mcu种类很多&#xff0c;如果是开发的时候需要对固件升级&#xff0c;整体还是比较容易的。不管是dap&#xff0c;还是st-link v2、j-link&#xf…