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

Qt步进电机上位机控制程序源代码:跨平台C/C++编写,支持多种端口类型与详细注释

Qt步进电机上位机控制程序源代码:跨平台C/C++编写,支持多种端口类型与详细注释

Qt步进电机上位机控制程序源代码Qt跨平台C/C++语言编写 支持串口Tcp网口Udp网络三种端口类型 提供,提供详细注释和人工讲解 1.功能介绍: 可控制步进电机的上位机程序源代码,基于Qt库,采用C/C++语言编写。 支持串口、Tcp网口、Udp网络三种端口类型,带有调试显示窗口,接收数据可实时显示。 带有配置自动保存功能,用户的配置数据会自动存储,带有超时提醒功能,如果不回复则弹框提示。 其中三个端口,采用了类的继承与派生方式编写,对外统一接口,实现多态功能,具备较强的移植性。 2.环境说明: 开发环境是Qt5.10.1,使用Qt自带的QSerialPort,使用网络的Socket编程。 源代码中包含详细注释,使用说明,设计文档等。 请将源码放到纯英文路径下再编译。 3.使用介绍: 可直接运行在可执行程序里的exe文件,操作并了解软件运行流程。 本代码产品特点: 1、尽量贴合实际应用,细节考虑周到。 2、注释完善,讲解详细,还有相关扩展知识点介绍。

By Ne0inhk
Redis 核心数据结构:String 类型深度解析与 C++ 实战

Redis 核心数据结构:String 类型深度解析与 C++ 实战

Redis 核心数据结构:String 类型深度解析与 C++ 实战 前言 在当今数据驱动的世界里,Redis 以其卓越的性能和丰富的数据结构,已成为内存数据库领域的翘楚。无论是作为高速缓存、消息队列,还是分布式锁的实现方案,Redis 的身影无处不在。而在 Redis 提供的所有数据结构中,String 类型无疑是基石中的基石。它不仅是构建其他复杂结构的基础,其自身强大的命令集也足以应对各种复杂的业务场景。 本文将以广受欢迎的 C++ Redis 客户端库 redis-plus-plus 为实战工具,系统性地、由浅入深地剖析 Redis String 类型的核心命令。我们将从最基础的 SET 和 GET 操作讲起,逐步探索包括过期时间设置、条件更新、批量操作、子字符串处理以及原子计数器在内的各种高级用法。 本文旨在为您提供一份不仅包含“如何做”,更解释“为什么这么做”的详尽指南。我们将深入探讨 redis-plus-plus

By Ne0inhk
嘿嘿 解决了Dev C++ 中文乱码(有效版)

嘿嘿 解决了Dev C++ 中文乱码(有效版)

这是博主第一篇博客!记录一下博主的小小小小解决史! 很早就下载用了Dev c++ ,但现在隔了很长时间没去用过了再次打开发现出现中文乱码的现象!在网站上翻阅了许久!终于解决了问题!困扰了许久! ——————————————————————— 这个中文乱码看着是真烦得慌!!! tips:不要急不要急,事情慢慢都能解决掉滴! 还有不要保存在C盘哦!最好都保存在D盘内!本博客示范的未命名1.c 保存于C盘桌面上是为了演示方便! ———————————————————————————  图1 这是我们原来出现中文乱码的界面 编译的时候会出现这个窗口   图一 (再说一遍!这个中文乱码在之前没解决掉问题的时候一看到这个就很烦! ) 图二是编译过后(中文乱码版) 图二          ————————————————————————— 第一种方法(也是博主强推亲测有效法) ·第一步         请点击左上角<控制台界面>左上角                选中<默认值D> 图三   操作第一步     ·第二步          将下方“使用旧版本

By Ne0inhk
【 C/C++ 算法】入门动态规划-----路径问题(以练代学式)

【 C/C++ 算法】入门动态规划-----路径问题(以练代学式)

>每日激励:“不设限和自我肯定的心态:I can do all things。 — Stephen Curry” 绪论 : 本章是动态规划的第二篇,本章将开始二维的动态规划,在二维中的动态规划本质和一维的分析来说差不太多,只不过状态表示从一维变成了二维,而在二维上所能管理的状态就从一维的两个变成了二维的三个,也就是x轴,y轴,数组中的值。若没看了解过动规算法,我强烈建议先看第一篇blog,因为当你看完第一篇你就对动规基本认识了,其中也就能认识到它的五步骤分析法,这里也就不扩充说明而是直接使用了 ———————— 早关注不迷路,话不多说安全带系好,发车啦(建议电脑观看)。 路径问题🛣️ 本章主要还是在二维数组中的进行的动态规划: 同样还是五步走:状态表示、状态方程、初始化、移动方向、返回结果 1. 其中在二维中状态表示就会和一位略有不同,不同本质一样: 从以 i 结尾.,… ==》从左上角到达 i j 位置,… 1. 当然在最后一题中发现上面这种常规方法实现不通,因为状态方程会受后面状态影响 2.

By Ne0inhk