Typescript泛型详解解读

泛型 : 在定义函数、接口、类的时候不能预先确定要使用的数据的类型,而是在使用函数、接口、类的时候才能确定数据的类型

普通方法示例:

需求:定义一个函数,传入两个参数,第一参数是数据,第二个参数是数量,函数的作用:根据数量产生对应个数的数据,存放在一个数组中

(() => {// 需求:定义一个函数,传入两个参数,第一参数是数据,第二个参数是数量,函数的作用:根据数量产生对应个数的数据,存放在一个数组中// 定义一个函数function getArr1(value: number, count: number): number[] {// 根据数据和数量产生一个数组const arr: number[] = []for (let i = 0; i < count; i++) {arr.push(value)}return arr}const arr1 = getArr1(10.25, 3)console.log(arr1)})()

普通方法示例2:

 需求:可以传入任意类型的数据,返回来的是存储这个任意类型数据的数组

(() => {//需求:可以传入任意类型的数据,返回来的是存储这个任意类型数据的数组function getArr3(value: any, count: number): any[] {// 根据数据和数量产生一个数组const arr: any[] = []for (let i = 0; i < count; i++) {arr.push(value)}return arr}const arr1 = getArr3(100.123, 3)const arr2 = getArr3('abc', 3)console.log(arr1)console.log(arr2)// arr1中存储的是数字类型的数据// arr2中存储的是字符串类型的数据console.log(arr1[0].toFixed(2)) // 没有任何的智能提示的信息(要么有方法名字的提示信息,要么有错误的提示信息)console.log(arr2[0].split('')) // 没有任何的智能提示的信息(要么有方法名字的提示信息,要么有错误的提示信息)})()

泛型方法示例:

(() => {function getArr4<T>(value: T, count: number): T[] {// 根据数据和数量产生一个数组// const arr: T[] = []const arr: Array<T> = []for (let i = 0; i < count; i++) {arr.push(value)}return arr}const arr1 = getArr4<number>(200.12345, 5)const arr2 = getArr4<string>('abcdefg', 5)console.log(arr1)console.log(arr2)console.log(arr1[0].toFixed(3))  // 有智能提示的信息console.log(arr2[0].split(''))   // 有智能提示的信息})()

以上代码详细解读:

  • function getArr4<T>(value: T, count: number): T[]
    • getArr4 是函数名。
    • <T> 是类型参数,它是一个类型占位符。通过使用泛型,这个函数可以处理不同类型的数据。
    • value: T 表示函数接受一个类型为 T 的参数 value,这个参数将作为数组元素的内容。
    • count: number 表示函数还接受一个 number 类型的参数 count,用于指定生成数组的长度。
    • : T[] 是函数的返回值类型,表示函数将返回一个元素类型为 T 的数组。
  • const arr: Array<T> = []:声明了一个名为 arr 的常量,它是一个类型为 Array<T>(等同于 T[])的数组,即元素类型为 T 的数组,用于存储生成的数组元素,初始化为空数组。
  • for (let i = 0; i < count; i++) { arr.push(value); }:通过 for 循环,根据 count 的值,将 value 重复 count 次添加到 arr 数组中。
  • return arr:循环结束后,返回生成的数组 arr
  • const arr1 = getArr4<number>(200.12345, 5):调用 getArr4 函数,明确指定类型参数 T 为 number。传入数值 200.12345 作为 value 参数,5 作为 count 参数。函数执行后会返回一个包含 5 个 200.12345 的数组,并将其赋值给 arr1
  • const arr2 = getArr4<string>('abcdefg', 5):调用 getArr4 函数,指定类型参数 T 为 string。传入字符串 'abcdefg' 作为 value 参数,5 作为 count 参数。函数执行后会返回一个包含 5 个 'abcdefg' 的数组,并将其赋值给 arr2
  • onsole.log(arr1[0].toFixed(3)):访问 arr1 数组的第一个元素(类型为 number),调用 toFixed(3) 方法将该数字四舍五入保留三位小数,并将结果打印到控制台。由于 arr1 的类型被明确为 number[],所以在访问 arr1[0] 时会有智能提示,编辑器能识别出 toFixed 方法是 number 类型的可用方法。
  • console.log(arr2[0].split('')):访问 arr2 数组的第一个元素(类型为 string),调用 split('') 方法将该字符串拆分成字符数组,并将结果打印到控制台。同样,因为 arr2 的类型被明确为 string[],在访问 arr2[0] 时会有智能提示,编辑器能识别出 split 方法是 string 类型的可用方法。

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

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

相关文章

[AI翻译] 语言指南(proto 3)

语言指南&#xff08;proto 3&#xff09; 语言指南&#xff08;proto 3&#xff09;| 协议缓冲区文档 --- Language Guide (proto 3) | Protocol Buffers Documentation 介绍如何在项目中使用 Protocol Buffers 语言的 proto3 修订版。 本指南描述了如何使用协议缓冲区语言来…

工作流引擎camunda7和liteflow的功能异同对比,性能对比,使用场景对比

Camunda 7 和 LiteFlow 是两个不同的工作流引擎&#xff0c;虽然它们都可以用来实现流程编排和管理&#xff0c;但它们的设计理念、功能特点和适用场景存在较大的差异。以下是对它们的功能和性能的详细对比&#xff1a; 1. 基本介绍 Camunda 7 定位&#xff1a;一款重量级的企…

解决npm install安装出现packages are looking for funding run `npm fund` for details问题

当我们运行npm install时&#xff0c;可能会收到类似以下的提示信息&#xff1a;“x packages are looking for funding.” 这并不是错误提示&#xff0c;也不会影响项目的正常运行。其实实在提醒有一些软件包正在寻求资金支持。 根据提示输入npm fund可以查看详细的信息&#…

小米Vela操作系统开源:AIoT时代的全新引擎

小米近日正式开源了其物联网嵌入式软件平台——Vela操作系统&#xff0c;并将其命名为OpenVela。这一举动在AIoT&#xff08;人工智能物联网&#xff09;领域掀起了不小的波澜&#xff0c;也为开发者们提供了一个强大的AI代码生成器和开发平台。OpenVela项目源代码已托管至GitH…

python定时监控端口脚本

python写了一个监控端口服务&#xff0c;自动重启的脚本 为了防止以后找不到代码&#xff0c;特别记录一下 import os import sys import threading import timeimport socket import subprocessdef check_port_and_run_script(port, script_path):# 创建一个socket对象sock …

2025_1_22打卡

402. 移掉 K 位数字 - 力扣&#xff08;LeetCode&#xff09; 279. 完全平方数 - 力扣&#xff08;LeetCode&#xff09;

【搞机】GMK-G3因特尔n100处理器核显直通win10虚拟机

环境 系统&#xff1a;Proxmox Virtual Environment 8.1.3 Linux内核&#xff1a;Linux version 6.5.13-6-pve (buildproxmox) (gcc (Debian 12.2.0-14) 12.2.0, GNU ld (GNU Binutils for Debian) 2.40) #1 SMP PREEMPT_DYNAMIC PMX 6.5.13-6 (2024-07-26T12:34Z) CPU&#x…

MECD+: 视频推理中事件级因果图推理--VLM长视频因果推理

论文链接&#xff1a;https://arxiv.org/pdf/2501.07227v1 1. 摘要及主要贡献点 摘要&#xff1a; 视频因果推理旨在从因果角度对视频内容进行高层次的理解。然而&#xff0c;目前的研究存在局限性&#xff0c;主要表现为以问答范式执行&#xff0c;关注包含孤立事件和基本因…

HTML5 History API

在 HTML5 的 History API 中&#xff0c;pushState 和 replaceState 方法也可以接受一个 state 对象作为参数。这些方法允许你在改变浏览器路由时不重新加载页面&#xff0c;并且可以附加一些自定义数据。 state 返回在 history 栈顶的 任意 值的拷贝。 let currentState h…

2024“博客之星”——我的博客成长与技术洞察

&#x1f31f;欢迎来到 我的博客 —— 探索技术的无限可能&#xff01; &#x1f31f;博客的简介&#xff08;文章目录&#xff09; 目录 一、引言二、个人成长与突破盘点&#xff08;一&#xff09;技能提升与知识拓展&#xff08;二&#xff09;创作风格与影响力提升&#xf…

学生管理系统C++版(简单版)详解

有错请指出 啊~&#xff0c;答应大家的来了 头文件&#xff1a; #include<iostream> #include<stdlib.h> #include<windows.h> iostream是标准头文件&#xff0c;stdlib.h也可以写成cstdlib&#xff0c;windows.h&#xff0c;用Sleep 数据定义&#xff…

Apache Hive 聚合函数与 OVER 窗口函数:从基础到高级应用

在大数据时代&#xff0c;Apache Hive 是处理和分析海量数据的强大工具。Hive 提供了丰富的聚合函数和强大的 OVER 窗口函数&#xff0c;能够帮助我们高效地进行数据分析。本文将综合介绍 Hive 的聚合函数和 OVER 窗口函数&#xff0c;结合实际使用场景和代码示例&#xff0c;帮…

KOC营销2.0:出海品牌在2025年春节的创新故事讲述

在全球化日益加深的今天&#xff0c;春节已不再是中国独有的节日符号&#xff0c;它逐渐成为了世界各地文化交融的一部分。对于出海品牌而言&#xff0c;春节不仅是连接中国消费者与海外市场的桥梁&#xff0c;更是展示品牌文化深度与创意的重要契机。KOC营销作为新时代的传播策…

最新-CentOS 7安装1 Panel Linux 服务器运维管理面板

CentOS 7安装1 Panel Linux 服务器运维管理面板 一、前言二、环境要求三、在线安装四、离线安装1.点击下面1 Panel官网链接访问下载&#xff0c;如未登录或注册&#xff0c;请登录/注册后下载2.使用将离线安装包上传至目标终端/tem目录下3.进入到/tem目录下解压离线安装包4.执行…

C++|开源日志库log4cpp和glog

文章目录 log4cpp 和 glog对比1. **功能对比**2. **易用性和配置**3. **性能**4. **线程安全**5. **日志输出**6. **功能扩展**7. **适用场景**8. **总结** 其它开源C日志库1. **spdlog**2. **easylogging**3. **Boost.Log**4. **loguru**5. **Poco Logging**6. **Qt Logging (…

高频次UDP 小包丢包分析

目录 背景测试方法测试结果case1: (经过多级交换机)case2: 长时测试(经过多级交换机)case3: 长时测试(设备直联)可能原因分析解决方法背景 UDP作为面向非连接的传输协议,并不能保证可靠交付。本文编写代码测试设备之间UDP小包传输的可靠性。 测试方法 发送侧基于豆包…

基于springboot+vue的高校社团管理系统的设计与实现

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

vim在末行模式下的删除功能

删除:d :1d #删除第1行 :1,5d #删除第一行至第五行 :g/^\s*$/d #删除文件中的空白行 ——g所有 ——^表示行首 ——$表示行尾 ——\s 空白符 ——* 0至多个 示例&#xff1a;

DRG_DIP 2.0时代医院程序结构转型与数据结构优化研究

一、引言 1.1 DRG_DIP 2.0 改革背景与意义 医保支付方式改革在医疗保障制度改革中占据着极为关键的地位&#xff0c;是推动医疗领域变革的核心力量。它犹如一把精准的手术刀&#xff0c;对医疗资源的合理分配、医疗服务质量的稳步提升以及医疗费用的有效控制起着决定性作用。…

基于springboot体育运动会比赛系统

基于Spring Boot的体育运动会比赛系统是一个专为体育运动会组织和管理设计的现代化解决方案。 一、系统背景与目的 随着人们对健康生活的追求和对体育运动的热爱&#xff0c;体育运动会在各个层面得到了广泛的开展。然而&#xff0c;传统的体育运动会组织和管理方式存在着效率…