项目中 TypeScript 类型推导 极简实战总结

项目中 TypeScript 类型推导 极简实战总结

(前端 90% 场景都能用,一看就会、一用就对)

我用最通俗、最实用 的方式讲:什么是类型推导 + 什么时候用 + 怎么用 + 不用会怎样


一、什么是 TS 类型推导?

TS 自动猜出变量/函数/返回值的类型,不用你手动写。

你不写类型,TS 也知道它是什么类型。

ts 复制代码
let name = "张三" // TS 自动推导出:string
let age = 18      // 自动推导出:number

二、类型推导的 5 种最常用场景(前端项目必用)

1. 变量自动推导(最基础)

ts 复制代码
const a = 123        // 推导:number
const b = true       // 推导:boolean
const c = [1,2,3]    // 推导:number[]

好处:不用写冗余类型,代码更干净。


2. 函数返回值自动推导(超级常用)

ts 复制代码
function add(a: number, b: number) {
  return a + b
}
// TS 自动推导出返回值是 number
// 你不用写:function add(a:number,b:number): number

什么时候必须手动写返回类型?

API 请求、复杂函数、为了可读性时写。


3. 对象自动推导(配合 interface)

ts 复制代码
const emp = {
  id: 1,
  name: "小明"
}
// TS 自动推导出 { id: number; name: string }

如果你定义了接口,TS 会严格推导

ts 复制代码
interface Employee { id: number; name: string }

const emp: Employee = { id:1, name:"xx" }
// 推导 + 约束 一起生效

4. 数组自动推导

ts 复制代码
const list = [1,2,3] // 推导:number[]
list.push(4)         // 正确
list.push("5")       // 报错

5. 异步请求 / API 自动推导(最重要)

你封装的 API:

ts 复制代码
getAll: () => api.get('/employees')

如果你写:

ts 复制代码
getAll: (): Promise<Employee[]> => api.get('/employees')

那么调用时:

ts 复制代码
const list = await employeeApi.getAll()
// TS 自动推导出 list 是 Employee[]

不用你再 (list as Employee\[\]) 强行转换!


三、什么时候必须手动写类型(不能靠推导)

1. 空数组

ts 复制代码
const list: Employee[] = []

不写会变成 any[],失去类型检查。

2. 函数参数

ts 复制代码
function fn(a: number) {}

参数不会自动推导,必须手动写。

3. 接口返回值(API)

ts 复制代码
getAll: (): Promise<Employee[]> => ...

为了安全 + 提示,必须写。

4. 组件 Props / 表单

ts 复制代码
const ruleForm: EmployeeForm = { ... }

四、一句话记住:

TS 能自动推出来的 → 不写

自动推不出来 / 不安全的 → 必须写


五、前端项目最佳实践(背会)

  1. 变量不写类型(自动推导)
  2. 函数参数必须写类型
  3. 函数返回值能推导就不写
  4. API 返回值必须写类型
  5. 对象、表单、接口必须用 interface 约束
  6. 空数组必须写类型
  7. 类型导入用 import type

六、最精简总结(你只需要记这句)

TypeScript 类型推导 = TS 自动猜类型

能推导就不写,不能推导才手写

API、表单、对象必须手动约束类型


相关推荐
珑墨23 分钟前
前端 AI 开发通用skill
前端
kyriewen24 分钟前
一个人+Cursor,7天上线付费小程序:第1天我就想放弃了
前端·微信小程序·cursor
大家的林语冰30 分钟前
Angular 王者归来,第 22 个主版本亮相,一大波前沿技术再度引领潮流!
前端·javascript·前端框架
老毛肚43 分钟前
jeecgboot TS + Vue 模板化 03
前端·javascript·vue.js
小林ixn44 分钟前
揭秘JavaScript面向对象:从栈模拟队列到原型链的深度剖析
javascript
下北沢美食家1 小时前
SSE 入门
前端
云计算磊哥@1 小时前
运维开发宝典023-WEB网站服务
运维·前端·运维开发
FlyWIHTSKY1 小时前
React 19 + Next.js 16(App Router)项目中集成 MSW
开发语言·javascript·vue.js
冰暮流星1 小时前
javascript之对象的建立-使用Object
开发语言·javascript·ecmascript
加点油。。。。1 小时前
【1.Obsidian渲染html文件】
前端·html·obsidian