前端高频面试题:TypeScript 篇(2026 最新版)

前端高频面试题:TypeScript 篇(2026 最新版)

TypeScript(TS)已成为现代前端开发的标配,尤其在 React、Vue、Angular 等框架中,几乎是大厂必考点。2026 年面试趋势:更注重类型安全高级类型工具实际项目应用tsconfig 配置。以下精选 20+ 高频题(基于最新大厂真题汇总),分为基础、中级、高级,并附详细解答和代码示例。建议结合项目实战记忆!

基础篇(必背,考察理解 TS 核心价值)
  1. 什么是 TypeScript?它与 JavaScript 的区别是什么?
    TypeScript 是 JavaScript 的超集(superset),由 Microsoft 开发,最终编译成纯 JS 运行。
    主要区别
    • TS 支持静态类型检查(编译时捕获错误),JS 是动态类型(运行时错误)。
    • TS 有接口、泛型、枚举、装饰器等 OOP 特性。
    • TS 需要编译(tsc),JS 直接运行。
    • TS 提升代码可维护性、IDE 智能提示,但增加学习成本。
  2. 为什么大厂前端项目都要用 TypeScript?优势有哪些?
    • 类型安全:编译时发现错误(如拼写错、类型不匹配),减少运行时 bug。
    • 更好重构:IDE 支持重命名、跳转、自动补全。
    • 团队协作:类型作为“文档”,明确接口契约。
    • 生态支持:React/Vue/Angular 官方推荐 TS。
    • 大型项目必备:代码规模大时,纯 JS 容易失控。
    • 原始类型:booleannumberstringnullundefinedsymbolbigintvoid
    • 对象类型:objectarraytuple(元组)、enum(枚举)。
    • 特殊类型:any(任意,关闭检查,不推荐)、unknown(未知,安全版 any)、never(永不返回)。

any、unknown、never 的区别?

类型描述使用场景安全性
any任意类型,关闭类型检查迁移旧 JS 项目、临时绕过低(不推荐)
unknown未知类型,必须先类型收窄API 返回不确定类型高(推荐)
never永不存在的值(如抛错函数)类型推断的底部类型-

示例:

let val:unknown='hello';if(typeof val ==='string'){// 类型收窄console.log(val.toUpperCase());}

TypeScript 的基本类型有哪些?示例:

let isDone:boolean=false;let num:number=6;let str:string='hello';let list:number[]=[1,2,3];// 或 Array<number>let tuple:[string,number]=['hello',10];// 元组
中级篇(高频,考察实际编码能力)
    • 联合类型:string | number → 值可以是其中一种。
    • 交叉类型:TypeA & TypeB → 值必须同时满足两种类型(对象合并)。
    • typeof 检查原始类型
    • instanceof 检查实例
    • in 检查属性
    • 字面量类型守卫(===)
    • 自定义类型守卫(is 关键字)

类型收窄(Type Narrowing)有哪些方式?示例:

functionpadLeft(value:string, padding:string|number){if(typeof padding ==='number'){returnArray(padding +1).join(' ')+ value;// padding 被收窄为 number}return padding + value;}

联合类型(|)和交叉类型(&)的区别?示例:

typeA={ a:string};typeB={ b:number};typeC=A&B;// { a: string; b: number }

泛型(Generics)是什么?应用场景?
泛型允许创建可复用组件,支持类型参数化。
示例:

functionidentity<T>(arg:T):T{return arg;}let output =identity<string>('hello');// T 推断为 string

场景:数组工具、Promise、React 组件 props、Vue defineProps 等。

interface 和 type 的区别?什么时候用哪个?

特性interfacetype
定义对象是(主要用途)
支持扩展(extends)是(用 & 交叉类型)
支持声明合并是(同名接口自动合并)
可定义联合/元组
可定义原始类型别名

推荐:对象/接口用 interface(支持合并,便于扩展);联合、映射、工具类型用 type。示例:

interfaceUser{ name:string;}interfaceUser{ age?:number;}// 自动合并typeID=string|number;
高级篇(大厂深挖,考察类型体操)
    • Partial<T>:所有属性可选
    • Required<T>:所有属性必选
    • Readonly<T>:所有属性只读
    • Pick<T, K>:挑选属性
    • Omit<T, K>:排除属性
    • Record<K, T>:键为 K,值为 T 的对象
    • Exclude<T, U> / Extract<T, U>:联合类型排除/提取
  1. tsconfig.json 中哪些配置最重要?
    • target:编译目标(如 es2020)
    • module:模块系统(如 esnext/commonjs)
    • strict:开启所有严格检查(强烈推荐)
    • noImplicitAny:隐式 any 报错
    • strictNullChecks:null/undefined 严格检查
    • esModuleInterop:更好导入 commonjs 模块
    • skipLibCheck:跳过库类型检查(加速编译)

映射类型(Mapped Types)如何使用?
通过 [K in keyof T] 遍历键创建新类型。
示例:

typeOptional<T>={[PinkeyofT]?:T[P]};// 等价于 Partial<T>

条件类型(Conditional Types)是什么?
T extends U ? X : Y
示例:

typeIsString<T>=Textendsstring?'yes':'no';typeTest1= IsString<'hello'>;// 'yes'

TypeScript 的工具类型(Utility Types)有哪些常用?示例:

typeUser={ name:string; age:number};typePartialUser= Partial<User>;// { name?: string; age?: number }
实战应用题(框架相关高频)
  1. 在 React/Vue 项目中如何使用 TypeScript?
    • React:用 .tsx,定义 props 类型(interface 或 type),useState()。
    • Vue:Vue 3 + TS 用 <script setup lang="ts">,defineProps()。
  2. 如何处理第三方库没有类型定义?
    • declare module '库名'; 或安装 @types/库名(DefinitelyTyped)。
    • 极端:用 any 断言,但不推荐。
面试建议
  • 准备项目:准备一个 TS + React/Vue 的个人项目,面试时能说类型如何提升代码质量。
  • 多练类型体操:LeetCode TS 版、Type Challenges(GitHub)。
  • 关注新特性:TS 5.x 的 const type parameters、infer 改进等。

这些题覆盖了 95% 以上的大厂考察点,背熟 + 理解原理,TS 面试稳过!如果需要某题的代码演示或扩展解答,随时问我~🚀

Read more

DeepSeek-R1-Distill-Llama-8B在数学解题中的应用案例

DeepSeek-R1-Distill-Llama-8B在数学解题中的应用案例 你是否曾经被复杂的数学题困扰,需要一个智能助手来帮你理清思路?DeepSeek-R1-Distill-Llama-8B可能就是你要找的解决方案。这个专门针对推理任务优化的模型,在数学解题方面展现出了令人印象深刻的能力。 本文将带你深入了解这个模型在数学领域的实际应用效果。通过多个真实案例展示,你会看到它是如何一步步解决从初中数学到竞赛级别的各种题目,不仅能给出正确答案,还能提供清晰的解题思路。 1. 模型能力概述 DeepSeek-R1-Distill-Llama-8B是DeepSeek团队推出的推理专用模型,专门针对数学、编程和逻辑推理任务进行了优化。虽然参数量只有80亿,但在数学解题方面的表现却相当出色。 从基准测试结果来看,这个模型在多个数学相关评测中都有不错的表现: * AIME 2024竞赛题:50.4%的通过率 * MATH-500数据集:89.1%的准确率 * GPQA钻石级难题:49.0%的解决率 这些数字意味着什么?简单来说,这个模型能够解决大约一半的高中数学竞赛题目

ComfyUI省钱攻略:按需付费玩AI绘画,比买显卡省90%

ComfyUI省钱攻略:按需付费玩AI绘画,比买显卡省90% 你是一位自由插画师,平时靠接稿和创作原创作品维持生计。最近听说AI绘画能大幅提升效率,比如快速生成草图、风格参考、配色方案,甚至直接出成图,于是你也想试试ComfyUI——这个目前最受欢迎的可视化AI绘图工作流工具。 但问题来了:本地跑ComfyUI需要高性能显卡,一张RTX 4090显卡要上万元,而你每周真正用AI辅助创作的时间可能只有3-4小时。如果花大价钱买显卡,显然不划算;去租云服务器?很多GPU服务商最低都是包月起步,动辄1500元/月,对你这种低频但高算力需求的用户来说,简直是“杀鸡用牛刀”。 有没有更聪明的办法? 当然有!今天我就来分享一套专为自由创作者、轻量使用者、预算敏感型用户设计的ComfyUI实战省钱方案:按需付费 + 灵活部署 + 高效使用,实测下来,相比包月或自购显卡,一年能省下90%以上的成本,而且操作简单,小白也能轻松上手。 学完这篇,你将掌握: * 如何在几小时内快速部署属于自己的ComfyUI环境 * 为什么“按小时计费”比“包月”更适合你 * 哪些镜像可以直接用,避免踩坑

文心一言API接入指南:手把手教你快速集成AI能力

文心一言API接入指南:手把手教你快速集成AI能力 关键词:文心一言API、大模型集成、开发者指南、AI能力调用、API接入实战 摘要:本文是面向开发者的文心一言API接入全流程指南,从注册账号到代码调用,用“手把手”式讲解+实战案例,带你快速掌握大模型能力集成方法。无论你是想给产品增加智能对话功能的中小团队,还是想尝试AI开发的个人开发者,读完本文都能轻松上手文心一言API! 背景介绍 目的和范围 近年来,以文心一言(ERNIE Bot)为代表的大语言模型(LLM)彻底改变了AI应用开发模式——开发者无需从头训练模型,通过API调用就能快速为产品注入智能对话、内容生成、文本理解等能力。本文聚焦文心一言API的实际接入流程,覆盖从账号注册到代码调试的全链路操作,帮助开发者快速将大模型能力集成到自己的应用中。 预期读者 * 中小团队开发者(需要为产品添加智能交互功能) * 个人开发者(想尝试AI应用开发) * 学生/技术爱好者(对大模型实际应用感兴趣) 文档结构概述 本文采用“知识铺垫→操作指南→实战验证→场景拓展”的逻辑,

AIGC Bar中的API站最新使用全指南

目录 总览:这篇“全指南”到底解决什么问题 站点定位:它不是“某一个模型”,而是“模型入口的兼容层” 中转/聚合的本质:你买的是“稳定接入体验”,不是“换皮接口” “OpenAI 兼容”的意义:把迁移成本压到改两三个配置项 计费心智:常见是“原价计费 + 充值折扣”或“统一账单” 从零开始:注册、控制台、令牌、分组这四件事要一次做对 账号体系:你真正要找到的是“控制台”和“令牌管理”这两个入口 令牌不是“账号密码”,而是“可撤销、可隔离、可审计”的工程凭据 分组是该站的“路由开关”:选错分组,表现像是“明明有钱却用不了” 一张表把“