什么是泛型约束?

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

在 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

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

相关推荐
Le_ee5 分钟前
ctfweb:php/php短标签/.haccess+图片马/XXE
开发语言·前端·php
爱上好庆祝14 分钟前
学习js的第七天(wed APIs的开始)
前端·javascript·css·学习·html·css3
KaMeidebaby1 小时前
卡梅德生物技术快报|冻干工艺开发:注射用心肌肽全流程参数优化与工程化方案
前端·其他·百度·新浪微博
Moment2 小时前
面试官:如果产品经理给你多个需求,怎么让AI去完成❓❓❓
前端·后端·面试
每天吃饭的羊2 小时前
JSONP
前端
gogoing2 小时前
ESLint 配置字段说明
前端·javascript
gogoing2 小时前
CSS 属性值计算过程(Computed Value)
前端·css
gogoing2 小时前
webpack 的性能优化
前端·javascript
桃花键神2 小时前
Bright Data Web Scraping指南 2026: 使用 MCP + Dify 自动采集海外社交媒体数据
大数据·前端·人工智能
gogoing2 小时前
await fetch() 的两阶段设计
前端·javascript