什么是泛型约束?

泛型约束是一种在泛型类型参数上定义约束条件的机制,它可以帮助我们限制泛型类型参数的取值范围。

在 TypeScript 中,可以使用 extends 关键字来定义泛型类型参数的约束条件。例如,我们可以定义一个泛型函数,要求它的类型参数必须是实现了某个接口的类型:

javascript 复制代码
interface HasLength {
  length: number;
}

function getLength<T extends HasLength>(arg: T): number {
  return arg.length;
}

上述代码中,我们定义了一个 HasLength 接口,它规定了一个 length 属性。然后,我们定义了一个泛型函数 getLength,它要求传入的类型参数 T 必须实现 HasLength 接口,也就是说,它必须有一个 length 属性。

这样,在调用 getLength 函数时,传入的参数必须满足 HasLength 接口的要求,否则会编译错误。例如,下面的调用就会报错:

javascript 复制代码
getLength(123); // 编译错误:数字类型没有 length 属性

而下面的调用则不会报错,因为字符串类型符合 HasLength 接口的要求:

javascript 复制代码
getLength('hello'); // 返回 5

通过泛型约束,我们可以限制泛型类型参数的范围,从而使代码更加健壮和可维护。

相关推荐
谢尔登8 小时前
10_从 React Hooks 本质看 useState
前端·ubuntu·react.js
辰同学ovo8 小时前
从全局登录状态管理学习 Redux
前端·javascript·学习·react.js
陈随易8 小时前
2年没用Nodejs了,Bun很香
前端·后端·程序员
donecoding9 小时前
Corepack 完全解析:从懵到懂,包管理器自由了
前端·node.js·前端工程化
yqcoder9 小时前
端经典面试题:为什么 0.1 + 0.2 !== 0.3?
前端·css
ZC跨境爬虫9 小时前
跟着 MDN 学 HTML day_12:(HTML网页图片嵌入)
前端·javascript·css·ui·html
光影少年9 小时前
reeact虚拟DOM、Diff算法原理、key的作用与为什么不能用index
前端·react.js·掘金·金石计划
用户059540174469 小时前
大模型记忆存储踩坑实录:LangChain 的 ConversationBufferMemory 让我排查了 6 小时
前端·css
是上好佳佳佳呀9 小时前
【前端(十二)】JavaScript 函数与对象笔记
前端·javascript·笔记
你真的快乐吗9 小时前
@fuxishi/svg-icon:一个 Vue 3 svg本地图标+iconify图标组件库,让图标管理不再头疼
前端·vue.js·typescript