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;
  }
}
相关推荐
亦暖筑序1 小时前
Java 8老系统AI Workflow实战:把一次性AI对话升级成可恢复工作流
java·后端
敲代码的彭于晏2 小时前
Bean 生命周期完全图解:前端同学也能看懂的 Spring 核心机制
java·前端·后端
plainGeekDev3 小时前
ButterKnife → ViewBinding
android·java·kotlin
kyriewen16 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
像我这样帅的人丶你还19 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩19 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia20 小时前
Mybatis的日志输入
java
亦暖筑序21 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
妙码生花21 小时前
现代前端的极致性能 icon 加载方案(死磕成功版)
前端·vue.js·typescript
用户298698530141 天前
Java 实现 Word 文档加密与权限解除
java·后端