前端高频面试题: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

在 Dynamics 365 Business Central 中落地 Copilot:从概念到实操

前言 在大型 BC 实施项目中,我们常见到业务用户期待更智能、更主动的 ERP 助手:自动提醒审批、发现订单异常、提醒发货延误或建议成本分摊。Copilot 把 AI 能力嵌入 BC,形成“可执行的建议与任务”。本文把理论与实践结合,帮助你把 Copilot 安全、高效地投入使用。 常见功能与示例分析 1、Suggest Line: 1. 可直接输入物料编号,描述,条码,属性,类别等部分信息,Copilot即可识别 可上传CSV文件,插入物料行 2、Analysis List 可在已有分析视图的基础上,进一步细化 下图为筛选某一阶段的分析视图,注意一定要指明按什么日期,比如Document date, 直接说明找2030年8月份的订单无法识别。 下图为可将某客户订单金额汇总 按物料类别显示平均成本 Keep it选择保留该分析视图

【AIGC文生图】通义万相2.1应用拓展与蓝耘云平台实践

【AIGC文生图】通义万相2.1应用拓展与蓝耘云平台实践

探索调参之道:通义万相2.1应用拓展与平台调优实践 近年来,随着生成模型不断迭代升级,通义万相在图像生成领域的表现愈发引人瞩目。相比于基础的文生图使用,如何在平台应用拓展和参数调优上发掘更大潜力,已成为众多开发者与工程师关注的热点。本文将从实际应用案例出发,分享一些调参心得与平台优化策略,并着重探讨蓝耘GPU平台在这方面的独特优势,力求帮助读者快速上手并走上创新之路。 一、通义万相2.1来临 前几日,通义官方发布了万相最新文生图模型2.1。 通义万相2.1在模型底层和交互体验上都有显著升级,具体来说: * 模型参数与语义理解升级 新版本参数规模已经突破千亿级别,使得对输入文本的语义捕捉更为精准,能更好地理解复杂描述,生成的图像在细节和质感上都有明显提升。与此同时,内置的智能改写功能可以自动优化用户输入,使得图像风格和表现更符合预期。 * 生成速度与细节表现的提升 得益于优化的算法和模型架构,生成速度大幅加快,尤其在高分辨率(最高支持200万像素)输出时,依然能保持流畅高效。同时,细节表现力增强后,无论是人物表情、光影效果还是场景布置,都能呈现得更加生动自

生成的甚么玩意 Õ_Õ ?基于 LoRA+Stable Diffusion 的100种动物图像生成

生成的甚么玩意 Õ_Õ ?基于 LoRA+Stable Diffusion 的100种动物图像生成

生成的甚么玩意 Õ_Õ ?基于 LoRA+Stable Diffusion 的100种动物图像生成 代码详见:https://github.com/xiaozhou-alt/Animals_Generationn 文章目录 * 生成的甚么玩意 Õ_Õ ?基于 LoRA+Stable Diffusion 的100种动物图像生成 * 一、项目介绍 * 二、文件夹结构 * 三、数据集介绍 * 四、Stable Diffusion 与 LoRA 模型介绍 * 1. Stable Diffusion 模型架构解析 * 1.1 变分自编码器(VAE) * 1.2 CLIP 文本编码器 * 1.3

【GitHub开源AI精选】WhisperX:70倍实时语音转录、革命性词级时间戳与多说话人分离技术

【GitHub开源AI精选】WhisperX:70倍实时语音转录、革命性词级时间戳与多说话人分离技术

系列篇章💥 No.文章1【GitHub开源AI精选】LLM 驱动的影视解说工具:Narrato AI 一站式高效创作实践2【GitHub开源AI精选】德国比勒费尔德大学TryOffDiff——高保真服装重建的虚拟试穿技术新突破3【GitHub开源AI精选】哈工大(深圳)& 清华力作 FilmAgent:剧本自动生成 + 镜头智能规划,开启 AI 电影制作新时代4【GitHub开源AI精选】Lumina - Image 2.0 文生图模型,以小参数量实现高分辨率多图生成新突破5【GitHub开源AI精选】探索 Mobile-Agent:X-PLUG 推出的创新型移动智能操作代理6【GitHub开源AI精选】吴恩达团队开源VisionAgent:用自然语言开启计算机视觉新时代7【GitHub开源AI精选】Oumi:一站式AI开发平台,涵盖训练、评估与部署全流程8【GitHub开源AI精选】深入剖析RealtimeSTT:开源实时语音转文本库的强大功能与应用9【GitHub开源AI精选】PodAgent:多智能体协作播客生成框架,