面试官:你为什么用 TS,别人用你就用?
myzbx 2025-08-31 06:00 5 浏览
前言
面试官盯着简历看了几秒,说:
"你项目里用了 TypeScript?为什么用?别人用你就用?"
我笑了笑,心里想:"这都被你发现了,TS 这玩意是跟风就能用得转的吗?"
JavaScript 一、痛点在哪?JavaScript 到底缺了啥?
先上个例子:
function fetchUser(id) {
return fetch(`/api/user/${id}`) #技术分享
.then(res => res.json())
.then(data => {
console.log(data.name.toUpperCase());
});
}
看起来正常吧?
但如果后端突然改了字段,把 name 改成了 username ,或者 name 根本是 null ,你就收获了 Cannot read property 'toUpperCase' of null 。
这种问题,JS 根本不会提前告诉你——等你上线才知道错。
TypeScript 二、TypeScript 能解决什么?
换个写法,用 TS:
type User = {
id: number;
name: string;
};
function fetchUser(id: number): Promise<User> { return fetch(`/api/user/${id}`).then(res => res.json()); }
fetchUser(1).then(user => { console.log(user.name.toUpperCase()); });
修正点:TS 无法直接感知后端字段变更,但能通过类型系统降低风险
实际作用:
- 显式契约约束 :开发者需手动维护 User 类型与后端接口的一致性
- 编译期校验 :若代码中误写 user.nome (拼写错误),TS 会立即报错
- 类型提示辅助 :IDE 会提示 name 字段存在,但无法验证后端真实返回
注意:TS 不能自动同步后端字段变更 ,需配合以下方案:
- 使用 openapi-generator 从 Swagger 自动生成类型定义
- 前后端约定接口变更时同步更新类型文件
- 通过运行时类型校验库(如 Zod)双重保障
JavaScript 三、现实场景对比:TS 和 JS 的工作体验差异
场景一:接口联调
JS 写法:
axios.get('/api/user/1').then(res => {
console.log(res.data.name);
});
TS 写法:
type ApiResponse<T> = {
code: number;
data: T;
};
interface User { id: number; name: string; }
axios.get<ApiResponse<User>>('/api/user/1').then(res => { console.log(res.data.data.name); });
优势:
- 自动提示字段类型
- 联调时接口结构变化能及时察觉
- 避免“data.data.xxx”的迷之结构出错
场景二:组件封装
JS 写法:谁知道 props 是啥,靠注释、靠记忆。
TS 写法:
interface ButtonProps {
text: string;
onClick: () => void;
}
const MyButton: React.FC<ButtonProps> = ({ text, onClick }) => { return <button onClick={onClick}>{text}</button>; };
优势:
- 参数提示一目了然
- 组件复用更安心
- 哪怕 3 个月没碰这段代码,也能快速读懂
TypeScript 四、TS 的隐藏技能,不止类型系统
如果你以为 TS 只是“JavaScript 加个类型检查”,你就低估它了。
下面这些,是 TS 为开发体验带来的质变:
智能提示 & IDE 体验飞升
- 函数参数和返回值提示
- 对象属性自动补全
- 引用跳转、查找定义、重命名统一处理
配合 VSCode,开发效率简直离谱地高。
更强的重构能力
- 字段名改了? 自动列出所有引用位置
- 类型系统确保“动一处知全局”
你能自信地“大胆动刀”,而不是“战战兢兢全局搜索”。
更安全地调用第三方库
TS 类型定义让你:
- 不用反复翻文档
- 参数写错直接红
- API 使用一目了然
比如 axios、lodash、dayjs,用 TS 用得飞起。
复杂逻辑建模能力
例如权限系统、表单引擎、配置项类型推导等高级场景:
type Role = 'admin' | 'user' | 'guest';
type Menu = { name: string; roles: Role[]; };
TS 提供联合类型、泛型、条件类型等强大建模能力,表达业务约束比 JS 更清晰。
团队协作更可靠
- 所有函数、组件的“输入输出”都清晰定义
- 新人接手代码有类型指引
- 编译期能发现大部分接口、参数、结构问题
TS 是“写给人看”的代码契约。
五、是不是跟风?其实是趋势
TS 不是“别人用我就用”,而是:
- 项目复杂度上来了,靠 JS 拿捏不住了
- 团队合作中,TS 是最好的沟通契约
- 前后端联调、组件封装、API SDK 全靠它
甚至在你意识到它的价值前,大厂早就用它写好了“脚手架、工具库、接口协议、eslint config”……
不是你跟风,而是 JS 世界不得不用它了。
TypeScript 六、TS 是不是更麻烦?值不值?
你可能会说:TS 要定义一堆类型,接口字段一更新就得改类型声明,岂不是很麻烦?
没错,它确实比 JS 多了一步类型维护。但你换来的,是:
- Bug 在线上前被发现
- 代码自带文档,新人也能看得懂
- 重构有安全感,不怕动一个炸一片
例如你写了这样一段接口类型:
interface User {
id: number;
name: string;
}
使用 TS 提前定义类型,这是“显式安全” ,不是多余的劳动。
反之用 JS 的话:
console.log(user.name.toUpperCase());
你不知道它啥时候崩,只能靠“测出来”。
而且,很多类型定义可以借助工具自动生成,比如配合 Swagger 的 openapi-typescript ,基本不费人工维护。
所以说:TS 是“用类型还债”,早还早安心 。
总结
TypeScript 的价值,不是“流行”这么简单,而是:
- 在开发初期就规避上线 BUG
- 提升多人协作效率
- 降低代码阅读与维护成本
- 强 IDE 支持和重构安全性
- 更适合复杂项目和长期演进
所以下次别人问你“为啥用 TS”?
请记住:
TS 的价值不是跟风,而是通过类型系统建立代码的‘显式契约’。比如在接口联调中,虽然它不能主动感知后端字段变更,但配合 OpenAPI 生成类型后,能在开发阶段就暴露接口不匹配的问题,避免线上故障。对于团队协作来说,类型定义本身就是最好的文档,能大幅降低维护成本。
TypeScript 感谢评论区指出文章问题,笔者TS知识还待学习,感谢包容!
下次再见!
相关推荐
- HTML DOM Progress 对象_html中的对象
-
Progress对象Progress对象是HTML5新增的。Progress对象表示一个HTML<progress>元素。<progress>元素表示任务...
- HTML DOM Script 对象_html document对象
-
Script对象Script对象表示一个HTML<script>元素。访问Script对象您可以使用getElementById()来访问<scrip...
- 虚拟DOM真的比操作原生DOM快吗?前端大神提供4个参考观点!收藏
-
尤雨溪:https://www.zhihu.com/question/31809713/answer/53544875VirtualDOM真的比操作原生DOM快吗?1.原生DOM操作v...
- 前沿|一种新的植入药物或可将HIV的预防时间持续一年
-
国外已经批准了一种叫做Truvada(中文名:特鲁瓦达)的药物用于HIV感染的暴露前预防。但是由于该药需要每天服用,因此有些人可能无法坚持,从而使得该药的预防效果降低。最近一项新的研究或许可以改变这种...
- 轻量级埋点sdk搭建,便捷更全面_埋点工具
-
引言借助埋点监控sdk,我们可以统计用户的点击,页面pv、uv,脚本错误、dom上报等关键信息等。一:项目初始化1.技术栈Tsrollup打包工具2.搭建项目npminit-ytsc--in...
- China's Humanoid Robotics Race Heats Up as Tesla's Optimus Hits a Wall
-
TMTPOST--Tesla'sonce-hypedhumanoidrobotproject,Optimus,hashitasnag.Partsprocurementhas...
- 单机训练速度提升640倍!独家解读快手商业广告模型GPU训练平台Persia
-
【导读】:近期,快手宣布将在2020年春节前实现3亿DAU,快手商业化营收步伐也随之加速。快手从2018年“商业化元年”开始推行个性化的广告推荐。截止5月底,快手DAU已经突破2亿。随着用户和使用时长...
- 电气字母符号大全,新人也能轻松上手
-
电气图形符号的形式分2大类:一、图形符号1、基本符号2、一般符号3、明细符号4、派生符号二、文字符号1、基本文字符号(1)单字母符号(2)双字母符号2、辅助文字符号三、最全电气字母符号:流电:DC直...
- Playwright 极速入门:1 小时搞定环境搭建与首个测试脚本
-
一、Playwright简介与核心优势Playwright是微软开源的现代化Web自动化工具,支持Chromium(Chrome/Edge)、Firefox、WebKit(Safari)三...
- 实用知识:常用继电器型号用途,技术参数
-
前言本文将分别着重介绍控制电路常用电器元件之继电器。帮你了解各系列继电器的性能,继电器的用途,规格,型号,以及技术数据。各种型号常用继电器简介:目前常用继电器有多种型号;1.JT3直流电磁继电器。2...
- Python、JavaScript和Rust的Web性能比较
-
Python使用FastApi测试;Node.JS使用Fastify;Rust则使用Actix。选择的Python和Node框架,是在搜索"最快的<某语言>api"时得...
- 不再需要 Javascript 做的五件事_不用javascript可以吗
-
作者:黄子毅有些功能用Javascript实现吃力不讨好,我们要综合使用技术工具,而不是只依赖JS。这篇文章就从五个例子出发,告诉我们哪些功能不一定非要用Javascript做。关注JS太久...
- 万字长文帮你彻底搞懂JS中的Promise
-
Promise是JavaScript异步编程中的重要概念,也是各种面试必考的知识点,今天和大家一起总结下Promise的前世今生,本文篇幅比较长,希望大家耐心阅读。一、同步与异步我们都知道JavaSc...
- 被偷家了!崩溃!!Element-plus组件测试的后续~
-
最新消息,VUE的slot移除产生内存泄漏问题已修复!!!前端佬们嗨起来~---------------------分割线-------------------------------这个是之前...
- 必看!Spring Boot 项目新老版本 Controller 低侵入式切换实战秘籍
-
在当今快速迭代的软件开发环境中,项目的迁移重构是许多开发团队都绕不开的工作。最近,业务方的一个项目就面临着这样的挑战,而在迁移重构的过程中,如何确保下游系统对接无感知成为了重中之重。具体来说,他们需要...
- 一周热门
- 最近发表
-
- HTML DOM Progress 对象_html中的对象
- HTML DOM Script 对象_html document对象
- 虚拟DOM真的比操作原生DOM快吗?前端大神提供4个参考观点!收藏
- 前沿|一种新的植入药物或可将HIV的预防时间持续一年
- 轻量级埋点sdk搭建,便捷更全面_埋点工具
- China's Humanoid Robotics Race Heats Up as Tesla's Optimus Hits a Wall
- 单机训练速度提升640倍!独家解读快手商业广告模型GPU训练平台Persia
- 电气字母符号大全,新人也能轻松上手
- Playwright 极速入门:1 小时搞定环境搭建与首个测试脚本
- 实用知识:常用继电器型号用途,技术参数
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)
- JS Loop For (32)