当前位置:首页 > 文章列表 > 文章 > 前端 > Typescript 中的泛型是什么 - 为什么使用它们,它们如何与代码示例一起使用

Typescript 中的泛型是什么 - 为什么使用它们,它们如何与代码示例一起使用

来源:dev.to 2024-09-11 15:45:59 0浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个文章开发实战,手把手教大家学习《Typescript 中的泛型是什么 - 为什么使用它们,它们如何与代码示例一起使用》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

Typescript 中的泛型是什么 - 为什么使用它们,它们如何与代码示例一起使用

介绍

什么是泛型?

typescript 中的泛型提供了一种创建可以使用多种类型而不是单一类型的组件的方法。它们允许您定义针对不同数据类型灵活且可重用的函数、类或接口,同时保持强大的类型安全性。

本质上,泛型使您能够编写能够适应不同类型的代码,而不会失去 typescript 类型系统的优势。这种灵活性有助于构建健壮且可维护的代码,可以处理各种场景。

为什么使用泛型?

  1. 代码可重用性:

泛型允许您编写可以操作多种类型的函数、类或接口,而无需重复代码。您可以使用适用于任何类型的单个通用版本,而不是为每种类型创建单独的函数版本。

    function identity(arg: t): t {
    return arg;
    }
    console.log(identity("hello")); // works with strings
    console.log(identity(42)); // works with numbers

在这个例子中,恒等函数是通用的。它可以接受并返回任何类型 t,使其可重用于不同的数据类型。

  1. 类型安全

泛型确保您的代码在提供灵活性的同时保持类型安全。当您使用泛型时,typescript 会检查传递给泛型组件的类型是否一致,从而减少出现运行时错误的可能性。

   function wrapinarray(value: t): t[] {
    return [value];
    }

    const stringarray = wrapinarray("hello"); // typescript knows this is a string array
    const numberarray = wrapinarray(42); // typescript knows this is a number array

这里,wrapinarray 返回一个包含所提供值的数组,typescript 确保数组的类型与值类型一致。

  1. 避免冗余

如果没有泛型,您最终可能会编写同一函数或类的多个版本来处理不同的类型。泛型消除了这种冗余,从而产生更干净、更易于维护的代码。

没有泛型的示例:

   function logstring(value: string): void {
    console.log(value);
    }

    function lognumber(value: number): void {
    console.log(value);
    }

泛型示例:

   function logvalue(value: t): void {
    console.log(value);
    }

    logvalue("hello"); // works with strings
    logvalue(42); // works with numbers

使用泛型,logvalue 函数可以处理任何类型,从而减少为每种类型编写单独函数的需要。

泛型在 typescript 中如何工作

泛型的基本语法

typescript 中的泛型使用占位符语法,通常用 表示,其中 t 代表“类型”。这允许您定义可以对各种数据类型进行操作而不会失去类型安全性的函数、类或接口。

function identity(value: t): t {
    return value;
}

const stringidentity = identity("hello world");
const numberidentity = identity(42);

通用函数

泛型函数是可以处理多种类型而无需重复代码的函数。

function wrapinarray(value: t): t[] {
    return [value];
}

const stringarray = wrapinarray("hello");
const numberarray = wrapinarray(123);

在此示例中,wrapinarray 函数将任何值包装在数组中。 typescript 在调用函数时推断类型,确保数组包含正确的类型。

通用接口

通用接口允许您定义可应用于不同类型的合约。

示例:

interface pair {
    first: t;
    second: u;
}

const nameagepair: pair = {
    first: "alice",
    second: 30,
};

通用类

泛型类对于创建可以存储或管理任何类型数据的数据结构非常有用。
示例:

class box {
    contents: t;

    constructor(value: t) {
        this.contents = value;
    }

    getcontents(): t {
        return this.contents;
    }
}

const stringbox = new box("gift");
const numberbox = new box(100);

说明:在此 box 类中,类型 t 允许该类存储和检索任何类型的数据。这种方法类似于您在现实生活中使用存储容器的方式,其中容器的形状(类型)可以根据其内容而变化。

通用约束

有时,您想要限制泛型可以接受的类型。这就是通用约束的用武之地。

function getproperty(obj: t, key: k) {
    return obj[key];
}

const car = { make: "toyota", year: 2022 };
const make = getproperty(car, "make"); // valid
const year = getproperty(car, "year"); // valid

在此示例中,getproperty 函数确保您传递的键必须是对象的有效属性。此约束通过强制密钥存在于给定对象上来帮助防止错误。

泛型的常见用例

使用数组和集合

泛型在处理数组或数据集合时特别有用,其中元素的类型可能会有所不同。

function mergearrays(arr1: t[], arr2: t[]): t[] {
    return arr1.concat(arr2);
}

const numbers = mergearrays([1, 2, 3], [4, 5, 6]);
const strings = mergearrays(["a", "b", "c"], ["d", "e", "f"]);

在此示例中,mergearrays 函数使用泛型类型 t 来合并任意类型的两个数组。无论数组包含数字、字符串还是任何其他类型,该函数都能无缝处理它们。

将其想象为组合两盒物品(例如水果或工具)。盒子内的物品类型可能有所不同,但组合它们的过程保持不变。

api响应处理

处理api响应时,不同端点返回的数据结构可能会有所不同。泛型可以通过创建适用于各种类型的灵活函数来简化对这些响应的处理。

interface apiresponse {
    status: number;
    data: t;
    message?: string;
}

function handleapiresponse(response: apiresponse): t {
    if (response.status === 200) {
        return response.data;
    } else {
        throw new error(response.message || "api error");
    }
}

const userresponse = handleapiresponse({
    status: 200,
    data: { name: "john", age: 30 },
});

const productresponse = handleapiresponse({
    status: 200,
    data: { id: 1, name: "laptop" },
});

在此示例中,handleapiresponse 函数适用于任何类型的 api 响应,无论是用户数据、产品详细信息还是其他内容。泛型类型 t 确保函数根据响应返回正确类型的数据。

想象一下在您家门口收到不同的包裹(api 响应)。内容可能有所不同(例如杂货、电子产品),但您有一种方法可以根据里面的内容正确打开每件商品的包装。

实用程序类型

typescript 提供了多种实用程序类型,它们在底层使用泛型来执行常见的类型转换。这些实用程序类型对于塑造和控制代码中的类型非常有用。

示例:

  1. partial:使 t 中的所有属性可选。
interface user {
    name: string;
    age: number;
    email: string;
}

const updateuser: partial = {
    email: "newemail@example.com",
};
  1. readonly:使 t 中的所有属性只读。
const user: readonly = {
    name: "john",
    age: 30,
    email: "john@example.com",
};

// user.age = 31; // error: cannot assign to 'age' because it is a read-only property.

  1. record:构造一个属性键为k、属性值为t的对象类型。
   const rolepermissions: record = {
    admin: ["create", "edit", "delete"],
    user: ["view", "comment"],
};

这些实用程序类型(部分、只读、记录)是使用泛型构建的,以提供灵活且可重用的类型转换。它们有助于更新对象的某些部分、确保不变性或在 typescript 中创建字典/映射等场景。

泛型高级主题

多种类型参数

typescript 允许在函数或类中使用多个类型参数,从而实现更大的灵活性并控制不同类型在代码中的交互方式。

function mergeobjects(obj1: t, obj2: u): t & u {
    return { ...obj1, ...obj2 };
}

const person = { name: "alice" };
const contact = { email: "alice@example.com" };

const merged = mergeobjects(person, contact);
// merged is of type { name: string } & { email: string }

在此示例中,mergeobjects 函数使用两个泛型类型参数 t 和 u 来合并两个对象。生成的对象结合了两个输入对象的属性,并使用 typescript 确保为合并结果推断出正确的类型

默认通用类型

typescript 还允许您定义泛型参数的默认类型。如果没有明确提供,此功能会提供后备类型,从而简化代码中泛型的使用。

function createpair(value1: t, value2: t): [t, t] {
    return [value1, value2];
}

const stringpair = createpair("hello", "world"); // defaults to [string, string]
const numberpair = createpair(10, 20); // explicitly set to [number, number]

createpair 函数的泛型类型 t 有一个默认的字符串类型。如果未指定类型,typescript 将使用字符串,但您可以在必要时通过提供不同的类型来覆盖它。

使用泛型进行类型推断

typescript 能够根据函数或类的使用方式推断泛型的类型。这减少了显式指定类型的需要,使代码更加简洁且更易于使用。

function wrapinarray(value: t): t[] {
    return [value];
}

const numberarray = wrapinarray(42); // typescript infers t as number
const stringarray = wrapinarray("hello"); // typescript infers t as string

说明:在wrapinarray函数中,typescript根据传递给函数的参数类型自动推断t的类型。这种推断类型的能力使泛型更加强大且易于使用,因为它通常消除了对显式类型注释的需要。

常见陷阱和最佳实践

过度使用泛型

虽然泛型是一个强大的功能,但它们有时可能会被过度使用,导致代码不必要地复杂且难以理解。

function overlygenericfunction(param1: t, param2: u): [t, u] {
    return [param1, param2];
}

在此示例中,该函数是通用的,但如果逻辑实际上并不依赖于它们是不同的类型,则可能不需要使用两个类型参数。这会使代码更难阅读和维护。

最佳实践:当泛型提供明显的好处时,例如当类型真正灵活且多样时,请使用泛型。如果特定类型或简单的联合类型也能完成这项工作,那么通常最好使用它们。

平衡灵活性和复杂性

泛型提供了灵活性,但平衡灵活性和简单性至关重要。使用泛型使代码过于复杂可能会使其更难以理解和维护。

温馨提示:

  • 使用泛型实现可重用性:如果您发现自己为多种类型编写相同的逻辑,泛型可以帮助使代码可重用。
  • 在适当的时候坚持使用特定类型:如果一个函数或类只适用于特定类型,那么使用该特定类型通常比使用通用类型更清晰。
  • 保持简单:当简单的解决方案就足够时,避免引入泛型。增加的复杂性应该由灵活性的需要来证明。

避免任何

在 typescript 中使用 any 会很快破坏该语言提供的类型安全性。泛型提供了一种更安全的替代方案,使您能够保持灵活性,同时仍然受益于 typescript 的类型系统。

function logValue(value: any): void {
    console.log(value);
}

function logGenericValue(value: T): void {
    console.log(value);
}

在第一个函数中,使用 any 意味着 typescript 不会检查值的类型,可能会导致运行时错误。相比之下,第二个函数使用泛型类型 t,在保持类型安全的同时仍然灵活。

最佳实践:只要需要灵活性,就优先选择泛型。这种方法可确保 typescript 继续强制执行类型安全,降低错误风险,并使您的代码更可预测且更易于调试。

结论

typescript 中的泛型是创建可重用、灵活且类型安全的代码的强大工具。它们允许您编写可与多种类型一起使用的函数、类和接口,从而减少冗余并增强代码可维护性。通过使用泛型,您可以避免任何陷阱,保持代码类型安全,并保持清晰和简单。

泛型在 typescript 中开辟了一个充满可能性的世界,使编写适应性强且可重用的代码变得更加容易。我鼓励您探索如何在您的项目中应用泛型。无论您是处理 api 响应、使用集合还是创建实用函数,泛型都可以显着提高代码的灵活性和健壮性。

终于介绍完啦!小伙伴们,这篇关于《Typescript 中的泛型是什么 - 为什么使用它们,它们如何与代码示例一起使用》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

版本声明
本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
win11绿屏重启怎么办 win11绿屏重启的解决方法win11绿屏重启怎么办 win11绿屏重启的解决方法
上一篇
win11绿屏重启怎么办 win11绿屏重启的解决方法
太阳之路 - 让我的标记更加迷人
下一篇
太阳之路 - 让我的标记更加迷人
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    508次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    497次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • SEO标题魔匠AI:高质量学术写作平台,毕业论文生成与优化专家
    魔匠AI
    SEO摘要魔匠AI专注于高质量AI学术写作,已稳定运行6年。提供无限改稿、选题优化、大纲生成、多语言支持、真实参考文献、数据图表生成、查重降重等全流程服务,确保论文质量与隐私安全。适用于专科、本科、硕士学生及研究者,满足多语言学术需求。
    7次使用
  • PPTFake答辩PPT生成器:一键生成高效专业的答辩PPT
    PPTFake答辩PPT生成器
    PPTFake答辩PPT生成器,专为答辩准备设计,极致高效生成PPT与自述稿。智能解析内容,提供多样模板,数据可视化,贴心配套服务,灵活自主编辑,降低制作门槛,适用于各类答辩场景。
    24次使用
  • SEO标题Lovart AI:全球首个设计领域AI智能体,实现全链路设计自动化
    Lovart
    SEO摘要探索Lovart AI,这款专注于设计领域的AI智能体,通过多模态模型集成和智能任务拆解,实现全链路设计自动化。无论是品牌全案设计、广告与视频制作,还是文创内容创作,Lovart AI都能满足您的需求,提升设计效率,降低成本。
    23次使用
  • 美图AI抠图:行业领先的智能图像处理技术,3秒出图,精准无误
    美图AI抠图
    美图AI抠图,依托CVPR 2024竞赛亚军技术,提供顶尖的图像处理解决方案。适用于证件照、商品、毛发等多场景,支持批量处理,3秒出图,零PS基础也能轻松操作,满足个人与商业需求。
    34次使用
  • SEO标题PetGPT:智能桌面宠物程序,结合AI对话的个性化陪伴工具
    PetGPT
    SEO摘要PetGPT 是一款基于 Python 和 PyQt 开发的智能桌面宠物程序,集成了 OpenAI 的 GPT 模型,提供上下文感知对话和主动聊天功能。用户可高度自定义宠物的外观和行为,支持插件热更新和二次开发。适用于需要陪伴和效率辅助的办公族、学生及 AI 技术爱好者。
    35次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码