TypeScript 中的接口、泛型与自定义类型

devtools/2024/10/18 10:28:58/

TypeScript 是一种超集语言,它为 JavaScript 添加了静态类型检查。通过 TypeScript,开发者可以获得更好的工具支持,并且能够编写出更加健壮的代码。本文将探讨 TypeScript 中的几个关键特性:接口、泛型以及如何创建自定义类型。

接口(Interfaces)

什么是接口?

接口是 TypeScript 中用于描述对象结构的一种类型。它可以定义一个类应该具备哪些属性、方法或者索引签名。接口可以确保类遵循了一定的设计模式或约定。

使用示例

typescript">interface Person {name: string;age?: number; // 可选属性[propName: string]: any; // 任意额外属性
}function greet(person: Person) {console.log(`Hello, ${person.name}!`);
}const me: Person = { name: "Alice", age: 30 };
greet(me); // 输出: Hello, Alice!

在这个例子中,我们定义了一个 Person 接口,它至少包含一个 name 属性,并允许有可选的 age 属性以及任何其他未指定的属性。

泛型(Generics)

什么是泛型?

泛型是一种在函数级别或者类级别提供类型的参数化机制。使用泛型可以编写灵活的组件,这些组件可以在运行时处理不同类型的数据而不牺牲类型安全性。

使用示例

typescript">function identity<T>(arg: T): T {return arg;
}let output = identity<string>("hello"); // 指定类型为字符串
console.log(output); // 输出: hello

在这个例子中,identity 函数接受一个类型参数 T,这使得我们可以用不同的具体类型来调用这个函数。

自定义类型(Custom Types)

什么是自定义类型?

自定义类型允许开发者创建新的类型别名,这可以简化复杂的类型定义,并使其更易于理解和复用。

使用示例

typescript">type UserId = string | number;function logUserId(id: UserId) {console.log(`User ID is ${id}`);
}logUserId(123); // 输出: User ID is 123
logUserId("abc123"); // 输出: User ID is abc123

这里定义了一个 UserId 类型,它是字符串或数字类型的一个别名。

结论

接口、泛型和自定义类型是 TypeScript 提供的强大工具,它们帮助开发者以一种类型安全的方式编写更加清晰、易于维护的代码。通过学习并运用这些概念,你可以提升你的 TypeScript 技能,并更好地应对复杂应用开发中的挑战。


http://www.ppmy.cn/devtools/117895.html

相关文章

后端Java-SpringBoot整合MyBatisPlus步骤(超详细)

1.新建项目。 2.点击完上一步的next之后&#xff0c;选择pom.xml文件中的依赖。 3.点击pom文件进行项目初始化。 按照下面的俩步骤刷新一下maven &#xff0c;让文件生效 4.新建一个application.yml文件 5. 新建一个数据库mp&#xff0c;在数据库中新建一张user表 6.连接数据…

LLaMa-Factory入门教程

LLaMa-Factory是一个基于人工智能技术的开源项目&#xff0c;专为大型语言模型&#xff08;LLMs&#xff09;的微调而设计。它提供了丰富的工具和接口&#xff0c;使得用户能够轻松地对预训练的模型进行定制化的训练和调整&#xff0c;以适应特定的应用场景。以下将详细介绍如何…

商务英语培训柯桥学英语到蓝天广场,OK是哪个词的缩写?可不是Okay!

OK是哪个词的缩写&#xff1f; 很多小可爱知道OK是Okay的缩写&#xff0c;但是你有没有好奇过&#xff0c;Okay (包括OK)到底从何而来&#xff1f; 与漫长的英语语言发展史相比&#xff0c;OK只能算是个新鲜词汇。 它首次见诸报端是在1839年。那时的美国社会正在进行大建设…

职业技能大赛-自动化测试笔记(PageObject)分享-4

前言 Page Object是Selenium自动化测试项目开发实践的最佳设计模式之一,主要是将每一个页面设计为一个Class,其中包含页面中需要测试的元素(按钮,输入框,标题 等),这样在Selenium测试页面中可以通过调用页面类来获取页面元素,这样巧妙的避免了当页面元素id或者位置变化…

基于Es和智普AI实现的语义检索

1、什么是语义检索 语义检索是一种利用自然语言处理&#xff08;NLP&#xff09;和人工智能&#xff08;AI&#xff09;技术来理解搜索查询的语义&#xff0c;以提供更准确和相关搜索结果的搜索技术&#xff0c;语义检索是一项突破性的技术&#xff0c;旨在通过深入理解单词和…

基于SSM+小程序的医院管理系统(医院1)(源码+sql脚本+视频导入教程+文档)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1 、功能描述 本医院管理系统小程序管理员功能有个人中心&#xff0c;用户管理&#xff0c;医生管理&#xff0c;排班信息管理&#xff0c;医生信息管理&#xff0c;科室信息管理&#xff0c;科室预约管…

搜索二叉树

一、二叉搜索树的概念 ⼆叉搜索树⼜称⼆叉排序树&#xff0c;它可以是⼀棵空树&#xff0c;或者是具有以下性质的⼆叉树: 若它的左⼦树不为空&#xff0c;则左⼦树上所有结点的值都⼩于等于根结点的值若它的右⼦树不为空&#xff0c;则右⼦树上所有结点的值都⼤于等于根结点的…

跟李沐学AI:自注意力和位置编码

自注意力 自注意力机制&#xff08;Self-Attention Mechanism&#xff09;&#xff0c;也被称为内部注意力&#xff08;Intra-attention&#xff09;或并行注意力&#xff08;Parallel Attention&#xff09;&#xff0c;是一种在深度学习模型中用于处理序列数据的机制。它允许…