TypeScript泛型开发常见错误解析

1. 过度使用泛型

错误示例

TypeScript 复制代码
// 不必要的泛型
function identity<T>(value: T): T {
  return value;
}

// 应该直接使用具体类型
function identity(value: string): string {
  return value;
}

正确做法

TypeScript 复制代码
// 只在需要灵活性时使用泛型
function identity<T>(value: T): T {
  return value; // 确实需要处理任意类型时
}

2. 泛型约束缺失

错误示例

TypeScript 复制代码
function getLength<T>(obj: T): number {
  return obj.length; // Error: Property 'length' does not exist on type 'T'
}

正确做法

TypeScript 复制代码
// 添加约束确保类型安全
interface HasLength {
  length: number;
}

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

3. 泛型推断问题

错误示例

TypeScript 复制代码
function merge<T, U>(obj1: T, obj2: U) {
  return { ...obj1, ...obj2 };
}

const result = merge({ name: "John" }, 25); // U 被推断为 number,但可能不是期望的

正确做法

TypeScript 复制代码
// 明确指定类型或添加约束
function merge<T extends object, U extends object>(obj1: T, obj2: U): T & U {
  return { ...obj1, ...obj2 };
}

// 或者明确指定类型
const result = merge<{ name: string }, { age: number }>(
  { name: "John" }, 
  { age: 25 }
);

4. 泛型默认值使用不当

错误示例

TypeScript 复制代码
class Container<T = any> { // 过度使用 any
  value: T;
  
  constructor(value: T) {
    this.value = value;
  }
}

正确做法

TypeScript 复制代码
// 使用更具体的默认类型
class Container<T = unknown> {
  value: T;
  
  constructor(value: T) {
    this.value = value;
  }
}

// 或者不提供默认值,强制使用者指定
class Container<T> {
  value: T;
  
  constructor(value: T) {
    this.value = value;
  }
}
相关推荐
2301_816651226 分钟前
C++中的享元模式变体
开发语言·c++·算法
大傻^9 分钟前
Spring AI Alibaba ChatClient实战:流式输出与多轮对话管理
java·人工智能·后端·spring·springai·springaialibaba
m0_583203139 分钟前
C++中的访问者模式变体
开发语言·c++·算法
小帅学编程11 分钟前
英语学习笔记
java·笔记·学习
浅念-16 分钟前
C ++ 智能指针
c语言·开发语言·数据结构·c++·经验分享·笔记·算法
布谷歌16 分钟前
Fastjson枚举反序列化:当字符串不是枚举常量名时,会发生什么?
开发语言·python
虚幻如影17 分钟前
python识别验证码
开发语言·python
不染尘.17 分钟前
最小生成树算法
开发语言·数据结构·c++·算法·图论
ChineHe20 分钟前
基础篇003_Python基础语法
开发语言·人工智能·python
学编程就要猛20 分钟前
JavaEE初阶:文件操作和IO
java·java-ee