Typescript高级: 深入理解ConstructorParameters类型及借助infer构建带参数的工厂实例方法

本文主要是介绍Typescript高级: 深入理解ConstructorParameters类型及借助infer构建带参数的工厂实例方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概述

  • 在TypeScript中,利用泛型和类型推断,我们可以编写出既灵活又安全的代码
  • 特别是在处理类和其实例化过程中,这些特性显得尤为重要
  • 我们着重关注构造函数参数(constructor parameters)的类型处理
  • 以及如何利用泛型工厂函数来创建类的实例
  • 构造函数是面向对象编程中初始化对象状态的核心手段
  • 在TypeScript中,通过为构造函数及其参数添加类型注解
  • 可以确保在创建对象时遵循预定义的类型规则,从而提高程序的健壮性

应用示例

// 定义一个简单的类  
class TestClass {public name: string;public classno: number;constructor(name: string, classno: number) {this.name = name;this.classno = classno;}greet() {  console.log(`Hello, my name is ${this.name} and I'm in class ${this.classno}.`);  }  
}  // 定义构造函数类型和构造函数参数类型  
type Constructor<T> = new (...args: any[]) => T;  
type ConstructorParametersType<T extends Constructor<any>> = T extends new (...args: infer P) => any ? P : never;  // 泛型工厂函数  
function createInstance<T>(constructor: Constructor<T>, ...args: ConstructorParametersType<Constructor<T>>): T {  return new constructor(...args);  
}  // 使用泛型工厂函数创建TestClass的实例并调用其方法  
const instance = createInstance(TestClass, "Alice", 123);  
instance.greet(); // 输出:Hello, my name is Alice and I'm in class 123.

1 ) ConstructorParametersType

  • TypeScript提供了ConstructorParameters内置类型
  • 它能够自动提取构造函数的参数类型
  • 但为了深入理解其原理,我们先自定义一个ConstructorParametersType
    type ConstructorParametersType<T extends new (...args: any[]) => any>= T extends new (...args: infer P) => any ? P : never;
    
  • 这段代码展示了TypeScript的条件类型与infer关键字的强大功能
  • 它定义了一个泛型类型T,要求T是一个构造函数类型
  • 即接受任意数量参数并返回某个类型的构造函数
  • 通过infer P,我们可以从T中推断出实际的参数类型数组P,最终作为输出类型
  • 如果T不符合预期构造函数类型,则默认返回never,确保类型安全

2 ) 泛型工厂函数:动态实例化的桥梁

  • 接下来,我们利用ConstructorParametersType来实现一个高度灵活的工厂函数createInstance

  • 此函数接收两个泛型参数:T代表要实例化的类的类型,而CP约束为对应的构造函数类型

  • 函数体内的类型声明 ...args: ConstructorParametersType<CP>保证了传入的参数与构造函数期望的参数类型完全匹配

    function createInstance<T, CP extends new (...args: any[]) => any>(constructor: CP,...args: ConstructorParametersType<CP>
    ): InstanceType<CP> {return new constructor(...args);
    }
    
  • 这里, InstanceType<CP> 是另一个TypeScript内置类型

  • 用于从构造函数类型推断出实例类型,确保返回值具有正确的类型

3 ) 总结

  • 在这个示例中,我首先定义了一个 TestClass
  • 它有一个构造函数接受 nameclassno 作为参数,并有一个eat方法用于打印学生信息
  • 之后,定义了一个工厂函数 createInstance
  • 它使用了TypeScript的内置类型 ConstructorParameters<T>来获取构造函数的参数类型
  • 以及InstanceType<T>来表示构造函数实例的类型,这样就不需要手动定义ConstructorParametersType
  • 通过这种方式,createInstance函数变得更加简洁且直接,同时仍然保持了类型安全,确保传入的参数类型与构造函数参数类型严格匹配
  • 最后,通过调用createInstance函数创建了TestClass的一个实例并调用了eat方法来验证功能

这篇关于Typescript高级: 深入理解ConstructorParameters类型及借助infer构建带参数的工厂实例方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1022714

相关文章

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

认识、理解、分类——acm之搜索

普通搜索方法有两种:1、广度优先搜索;2、深度优先搜索; 更多搜索方法: 3、双向广度优先搜索; 4、启发式搜索(包括A*算法等); 搜索通常会用到的知识点:状态压缩(位压缩,利用hash思想压缩)。

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

如何在页面调用utility bar并传递参数至lwc组件

1.在app的utility item中添加lwc组件: 2.调用utility bar api的方式有两种: 方法一,通过lwc调用: import {LightningElement,api ,wire } from 'lwc';import { publish, MessageContext } from 'lightning/messageService';import Ca

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了