面试官:你为什么用 TS,别人用你就用?

前言

面试官盯着简历看了几秒,说:

"你项目里用了 TypeScript?为什么用?别人用你就用?"

我笑了笑,心里想:"这都被你发现了,TS 这玩意是跟风就能用得转的吗?"

一、痛点在哪?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 能解决什么?

换个写法,用 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 无法直接感知后端字段变更,但能通过类型系统降低风险

🟢 实际作用:

  1. 显式契约约束:开发者需手动维护 User 类型与后端接口的一致性
  2. 编译期校验:若代码中误写 user.nome(拼写错误),TS 会立即报错
  3. 类型提示辅助:IDE 会提示 name 字段存在,但无法验证后端真实返回

⚠️ 注意:TS 不能自动同步后端字段变更,需配合以下方案:

  • 使用 openapi-generator 从 Swagger 自动生成类型定义
  • 前后端约定接口变更时同步更新类型文件
  • 通过运行时类型校验库(如 Zod)双重保障

三、现实场景对比: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 个月没碰这段代码,也能快速读懂

顺嘴提一句,技术大厂,前后端-测试机会,全国一线及双一线城市均有[坑位],待遇和稳定性还不错,感兴趣看看。

四、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 世界不得不用它了。

六、TS 是不是更麻烦?值不值?

你可能会说:TS 要定义一堆类型,接口字段一更新就得改类型声明,岂不是很麻烦?

没错,它确实比 JS 多了一步类型维护。但你换来的,是:

  • 🚨 Bug 在线上前被发现
  • 🧠 代码自带文档,新人也能看得懂
  • 🧰 重构有安全感,不怕动一个炸一片

例如你写了这样一段接口类型:

interface User {
  id: number;
  name: string;
}

使用TS提前定义类型,这是“显式安全”,不是多余的劳动。

反之用 JS 的话:

console.log(user.name.toUpperCase()); // name 是不是 null?你得祈祷

你不知道它啥时候崩,只能靠“测出来”。

而且,很多类型定义可以借助工具自动生成,比如配合 Swagger 的 openapi-typescript,基本不费人工维护。

所以说:TS 是“用类型还债”,早还早安心

总结

TypeScript 的价值,不是“流行”这么简单,而是:

  • 🌟 在开发初期就规避上线 BUG
  • 🌟 提升多人协作效率
  • 🌟 降低代码阅读与维护成本
  • 🌟 强 IDE 支持和重构安全性
  • 🌟 更适合复杂项目和长期演进

所以下次别人问你“为啥用 TS”?

请记住:

TS 的价值不是跟风,而是通过类型系统建立代码的‘显式契约’。比如在接口联调中,虽然它不能主动感知后端字段变更,但配合 OpenAPI 生成类型后,能在开发阶段就暴露接口不匹配的问题,避免线上故障。对于团队协作来说,类型定义本身就是最好的文档,能大幅降低维护成本。

感谢评论区指出文章问题✅,笔者TS知识还待学习,感谢包容!

——转载自:不爱说话郭德纲

#我的求职进度条#
全部评论

相关推荐

xdm&nbsp;早上喝奶茶差点喷出来。事情是这样的,我们班有个哥们儿,简称&nbsp;L,去年秋招拿了字节sp,专业方向是后端。我们当时都震惊:这哥们儿平时课上从来不发言,期末小组作业基本是划水的那种,刷题平台&nbsp;commit记录我点进去看过,绿格子稀稀拉拉。但他面试一路绿灯。一面二面三面&nbsp;hr&nbsp;面,全过,给的还是sp。当时班级群里恭喜他的、问他经验的、约饭的,热闹了一周。他说自己"运气好,准备充分"。我们都信了,直到三月初他入职。入职第二周开始,班里另一个进字节的同学W(在隔壁组的)开始跟我他的不对劲。一开始是写代码慢,后来写不出来,再后来是组里&nbsp;mentor&nbsp;让他fix&nbsp;一个简单&nbsp;bug&nbsp;都搞了一下午没动静。最离谱的是上周。W&nbsp;说他们大部门搞了个新人分享会,让新人讲一下自己负责模块的设计思路。L&nbsp;上去讲了&nbsp;20分钟,全程念稿子,问答环节别人随便问一个"那你这里为什么用&nbsp;Redis&nbsp;不用&nbsp;Memcached",他直接卡&nbsp;30秒说"这个我回去再确认一下"。会后他&nbsp;mentor&nbsp;直接找&nbsp;leader&nbsp;谈,leader&nbsp;找&nbsp;hr&nbsp;谈,hr调出了他面试录像,全程对比口型和回答节奏,发现他二三面有大量时长在偷偷看屏幕外(推测开了双机位&nbsp;AI&nbsp;答题)。(这段是&nbsp;W后来转述给我的,他自己也是听他组里同事八卦来的)昨天下班前,W&nbsp;告诉我L&nbsp;被辞退了,让他自己走,不走就走仲裁但会发函到学校。L&nbsp;现在已经回学校了,朋友圈仅三天可见。我说真的,我不是个心眼小的人,但是我看到这个消息的时候真的有种"嗯,挺好"的感觉。去年秋招我投字节后端,简历挂。我准备了八个月,背&nbsp;八股&nbsp;+&nbsp;刷&nbsp;500&nbsp;题&nbsp;+项目改了三版,连面试机会都没拿到。班里这哥们儿凭着一个外挂上岸,最后还是被甩出来了。不是说作弊就一定会被发现,但是当面试拿到的&nbsp;offer远远超出真实能力的时候,迟早会有这一天。试用期三个月不是给你过家家的,是真的要写代码、要在会议上回答问题、要扛需求的。我现在反而有点同情他。同情他相信"上岸就是终点"。发出来不是为了嘲笑谁,就是想说给那些正在被身边作弊上岸的同学搞得很&nbsp;emo&nbsp;的&nbsp;uu&nbsp;们听——别急,回旋镖很长,但它一定会回来。你继续刷你的题,写你的项目,背你的八股。该是你的迟早是你的,不是你的早晚还得还回去。xdm&nbsp;共勉。
牛客12588360...:我不想评论面试方式,作弊是绝对不对的,但是你八股加刷题也不过是个做题小子,他穿帮纯粹是他菜,你也没有高明到哪里去
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务