当前位置: 首页 > article >正文

你的JS代码总在半夜崩溃?TypeScript来“上保险”了

你有没有经历过凌晨三点线上报“Cannot read property ‘name’ of undefined”你爬起来一看原来是后端返回的数据少了一层。如果JS有“类型检查”这种悲剧根本不会发生。今天我们就来认识TypeScript——给JavaScript买了一份“意外险”。前言JavaScript就像个自由散漫的天才你给它一个字符串它当数字用你忘记传参数它给你个undefined你访问对象不存在的属性它笑眯眯地说“没事我给你undefined”。这种灵活在小型项目里很爽但项目一大就成了噩梦。TypeScript简称TS就是来解决这个问题的。它给JS加上了类型系统在代码运行之前就帮你检查类型错误。就像给代码装了安检门不规范的写法根本过不去。一、TypeScript是啥JS的“严格模式”Pro MaxTypeScript是微软开发的开源语言它是JavaScript的超集。意思是所有合法的JS代码在TS里也合法。TS只是给JS加了类型注解和一些新特性然后编译成干净的JS。// JS写法functiongreet(name){returnHello, name;}// TS写法加了类型functiongreet(name:string):string{returnHello, name;}greet(123);// ❌ 报错参数不能是数字你看TS在编译阶段就抓住了错误不用等到运行时。二、为什么要用TS三个字稳、爽、香稳类型错误在写代码时就暴露而不是在用户手里炸。爽编辑器智能提示飞起不用记方法名、参数顺序。香代码即文档看函数签名就知道怎么用。据统计使用TS的项目早期Bug能减少15%~25%。对于中大型项目TS几乎是标配。三、基础类型TS的“基本词汇”TS支持JS的所有类型还加了一些新的。1. 原始类型letname:string张三;letage:number18;letisStudent:booleantrue;letnothing:nullnull;letnotDefined:undefinedundefined;letbig:bigint100n;letsym:symbolSymbol(id);2. 数组letlist1:number[][1,2,3];letlist2:Arraystring[a,b];// 泛型写法3. 元组固定长度和类型的数组letperson:[string,number][张三,18];person[0]李四;// OKperson[1]20;// ❌ 报错第二个元素必须是数字4. 枚举给一组数字起名字enumColor{Red,Green,Blue}letc:ColorColor.Red;console.log(c);// 0默认从0开始// 自定义值enumStatus{Success200,NotFound404}5. Any万能类型慎用letnotSure:any4;notSure字符串;// OKnotSuretrue;// OKany会关闭类型检查相当于回到JS。尽量少用除非你确定这个值无法预知类型。6. Unknown安全的Anyletvalue:unknownhello;value123;// OK// console.log(value.toUpperCase()); // ❌ 报错unknown不能直接调用方法if(typeofvaluestring){console.log(value.toUpperCase());// 类型收窄后可用}unknown比any安全因为使用前必须先判断类型。7. Void没有返回值functionwarnUser():void{console.log(警告);}// 变量声明为void类型只能赋值为null或undefinedstrict模式下只能undefined8. Never永远不会发生的类型functionerror(message:string):never{thrownewError(message);}functioninfiniteLoop():never{while(true){}}四、类型注解给变量贴标签TS的核心就是类型注解在变量、函数参数、返回值后面加上: 类型。letmyName:string张三;functionadd(a:number,b:number):number{returnab;}但TS很智能很多时候可以类型推断不用显式写letage18;// TS自动推断为numberage18;// ❌ 报错五、接口Interface定义对象的形状接口是TS里最常用的功能用来描述对象的结构。interfacePerson{name:string;age:number;email?:string;// 可选属性readonlyid:number;// 只读属性}constzhangsan:Person{name:张三,age:18,id:1};zhangsan.id2;// ❌ 报错只读属性不能改接口还可以描述函数类型interfaceAddFunc{(a:number,b:number):number;}constadd:AddFunc(x,y)xy;六、类型别名Type给类型起外号类型别名和接口很像但能表示联合类型、元组等更复杂的类型。typeIDstring|number;// 联合类型typePoint[number,number];// 元组typeCallback(data:string)void;letuserId:ID123;userIdabc;接口 vs 类型别名接口可以扩展extends类型别名用交叉。接口可以重复定义自动合并类型别名不能重复。推荐优先用接口描述对象用类型别名描述联合、元组等。七、实战用TS写一个简单的函数// 需求格式化用户信息interfaceUser{name:string;age:number;address?:string;}functionformatUser(user:User,withAddress:booleanfalse):string{letbase${user.name},${user.age}岁;if(withAddressuser.address){base, 地址${user.address};}returnbase;}constu:User{name:李四,age:20,address:北京};console.log(formatUser(u,true));// 李四, 20岁, 地址北京如果你在编辑器里打formatUser(它会提示参数类型和返回值类型爽不爽八、常见坑点与建议不要滥用anyany越多TS的价值越低。实在不知道类型先写unknown。严格模式开启strict: truetsconfig.json让TS更严格地检查。第三方库大多数库都有types/xxx类型定义安装后就能获得智能提示。编译后的JSTS只负责编译时检查运行时还是JS类型信息会被擦除。九、总结TS不是敌人是保镖给JS加上类型提前发现错误。基础类型、接口、类型别名是核心工具。用好类型推断少写冗余注解。逐步迁移老项目从.js改成.ts开启allowJs: true。学TS并不难你只需要把“写JS时的心理预期”明确写出来。明天我们继续深入TypeScript聊聊高级类型——泛型、联合类型、交叉类型、类型保护让你写出更灵活更安全的代码。如果你觉得今天的“保险课”够实在点个赞让更多人看到。我们明天见

相关文章:

你的JS代码总在半夜崩溃?TypeScript来“上保险”了

你有没有经历过:凌晨三点,线上报“Cannot read property ‘name’ of undefined”,你爬起来一看,原来是后端返回的数据少了一层。如果JS有“类型检查”,这种悲剧根本不会发生。今天我们就来认识TypeScript——给JavaSc…...

DejaVuSansMono嵌入式位图字体库深度解析

1. 项目概述DejaVuSansMono 是一款专为嵌入式图形界面(尤其是 Cariad 显示框架)深度优化的开源位图字体库。它并非通用型矢量字体渲染引擎,而是将 DejaVu Sans Mono 字体家族经专业栅格化、字形精修与内存布局重构后生成的静态字模数据集合。…...

OpenClaw学习助手:Phi-3-mini-128k-instruct自动生成技术问答集

OpenClaw学习助手:Phi-3-mini-128k-instruct自动生成技术问答集 1. 为什么需要自动化学习助手 作为一名技术文档的深度用户,我经常面临一个困境:阅读大量文档后,如何快速检验自己的理解是否正确?传统做法是手动整理问…...

嵌入式轻量级时间解耦引擎:逻辑Tick与物理循环分离

1. 项目概述bluemicro_engine是一个面向嵌入式实时系统的轻量级时间解耦引擎,其核心设计目标是在硬件资源受限的微控制器(如 Cortex-M0/M3/M4)上,构建一个与用户输入响应、CPU主频波动及外设时序无关的确定性执行循环。它并非通用…...

告别路由器!用ESP32-NOW和Arduino IDE打造你的第一个无线传感器网络(附完整代码)

用ESP32-NOW构建去中心化传感器网络的实战指南 去年夏天,我在一个没有Wi-Fi覆盖的农场部署环境监测系统时,第一次深刻体会到ESP32-NOW的价值。传统方案需要架设路由器和中继器,而使用ESP32-NOW,仅用五块开发板就实现了半径300米范…...

数据库安全与运维管控(一):MySQL、PG与Oracle原生审计机制对比

在满足等保2.0、SOC2 或金融合规审查时,“开启数据库审计”是硬性指标。合规要求企业必须记录“谁、在什么时间、执行了什么SQL、结果如何”。面对这个需求,开发和运维通常首先想到的是利用数据库引擎自带的原生审计功能。但在海量并发(高 QP…...

Lixie数码管驱动库深度解析:WS2812B嵌入式显示控制实践

1. Lixie 数码管驱动库技术解析:面向嵌入式工程师的深度实践指南Lixie 是一款专为驱动“Lixie 边缘导光数码管”(Edge-Lit Digit Display)设计的 Arduino 兼容库。它并非传统真空管或七段 LED,而是一种融合光学设计与现代 LED 控制…...

算法复杂度的视觉化表达与教学研究的技术

引言算法复杂度作为计算机科学核心概念,其抽象性常导致学习障碍。视觉化表达与教学研究旨在通过直观手段提升理解效率。本大纲从理论基础、视觉化工具、教学方法、案例分析和未来方向展开。理论基础算法复杂度定义与分类(时间/空间复杂度) 大…...

2026年阿里国际站数字人直播服务商评测

2026 阿里国际站数字人直播服务商选型参考:基于五大维度的评测分析 开篇 随着跨境电商行业的竞争加剧,阿里国际站商家对高效获客工具的需求日益迫切,AI 数字人直播凭借 24 小时不间断开播、降本增效的核心优势,已经成为跨境商家突破时区限制、提升询盘转化的核心抓手。 …...

OpenClaw+千问3.5-35B-A3B-FP8:自媒体图文内容自动化生产

OpenClaw千问3.5-35B-A3B-FP8:自媒体图文内容自动化生产 1. 为什么选择自动化内容生产 作为一个长期运营技术自媒体的创作者,我每天需要花费大量时间在内容生产上:从选题策划、素材收集、文案撰写到排版发布,整个过程往往需要4-…...

**基于Python的基因序列分析工具链:从原始数据到功能注释全流程实战**

基于Python的基因序列分析工具链:从原始数据到功能注释全流程实战 在生物信息学领域,基因分析已成为理解生命本质的核心手段之一。无论是疾病机制探索、药物靶点筛选还是群体遗传研究,高效的基因序列处理能力都至关重要。本文将带你构建一套完…...

告别迷茫!ESP-IDF下LVGL驱动ST7789/ILI9341屏幕的引脚配置与Menuconfig选项全解析

告别迷茫!ESP-IDF下LVGL驱动ST7789/ILI9341屏幕的引脚配置与Menuconfig选项全解析 第一次在ESP32上尝试LVGL时,面对密密麻麻的Menuconfig选项和复杂的引脚配置,相信不少开发者都会感到无从下手。本文将带你深入理解ESP-IDF框架下LVGL显示驱动…...

mac下OpenClaw开发环境搭建:调试千问3.5-27B技能插件

mac下OpenClaw开发环境搭建:调试千问3.5-27B技能插件 1. 为什么需要本地开发环境 去年第一次接触OpenClaw时,我天真地以为所有技能开发都能在云端完成。直到尝试修改一个飞书会议纪要插件时,才发现每次测试都要经历"改代码→打包→上传…...

JavaScript this 关键字详解

JavaScript this 关键字详解 引言 在JavaScript中,this 是一个非常重要的关键字,它用来指代当前执行上下文中的对象。理解 this 的行为和作用域对于编写高效、可维护的JavaScript代码至关重要。本文将深入探讨 this 的概念、用法以及在不同场景下的表现。 什么是 this? …...

基于Python的IT行业岗位数据分析与可视化

摘要本文设计并实现了一个基于Python的IT行业岗位数据分析与可视化。随着信息技术的快速发展,数据分析和可视化技术在各个领域得到了广泛应用。本研究以IT行业招聘数据为研究对象,采用Python等技术,构建了一个功能完善的数据分析与可视化系统…...

拆穿名词诈骗!用大白话理解晦涩难懂的AI概念媳

1. 架构背景与演进动力 1.1 从单体到碎片化:.NET 的开源征程 在.NET Framework 时代,构建系统主要围绕 Windows 操作系统紧密集成,采用传统的封闭式开发模式。然而,随着.NET Core 的推出,微软开启了彻底的开源与跨平台…...

再次革新 .NET 的构建和发布方式(一)日

本文能帮你解决什么? 1. 搞懂FastAPI异步(async/await)到底在什么场景下能真正提升性能。 2. 掌握在FastAPI中正确使用多线程处理CPU密集型任务的方法。 3. 避开常见的坑(比如阻塞操作、数据库连接池耗尽、GIL限制)。 …...

同事离职,他在大群里发了一句“感谢一路相伴,江湖再见”,刚发出去,HR就让他撤回,理由是工作群不要发与工作无关的内容。

今天摸鱼的时候,听到一个极其荒诞又极其现实的职场鬼故事。隔壁部门的老李提了离职,今天是last day。这哥们儿可能平时武侠小说看多了,临走前在几百人的公司大群里发了一句:“感谢一路相伴,江湖再见”。结果呢&#xf…...

【2025最新】基于SpringBoot+Vue的游戏销售平台管理系统源码+MyBatis+MySQL

摘要 随着互联网技术的飞速发展,数字化娱乐产业迎来了前所未有的增长机遇。游戏作为数字娱乐的核心组成部分,其市场规模逐年扩大,用户需求日益多样化。传统的游戏销售模式已无法满足现代消费者的便捷性和个性化需求,亟需一个高效…...

孤能子视角:Kimi自我分析诊断[2],静态同构分析

(这也是Kimi的自分析诊断,上一分析为动态涌现法,这是静态同构法。里面所述技术及数值是否真实?)场域切换:静态同构模式已激活X光切片:当前互动场的截面解剖时间已冻结。以下是对"此刻的我"这一关系势能凝结体…...

代码生成利器:OpenClaw调用Qwen3.5-9B自动化开发脚本

代码生成利器:OpenClaw调用Qwen3.5-9B自动化开发脚本 1. 为什么需要自动化代码生成 作为一名长期与数据打交道的开发者,我每天都要面对各种重复性的数据处理任务。从简单的CSV清洗到复杂的多表关联分析,这些工作往往占据了我60%以上的编码时…...

数字信号完整性分析:眼图原理与应用详解

1. 眼图基础概念解析眼图(Eye Diagram)是数字信号完整性分析中最重要的工具之一。作为一名硬件工程师,我几乎每天都会用到眼图来分析高速信号的传输质量。简单来说,眼图就是将大量数字信号波形叠加在一起形成的图形,因…...

OpenClaw自动化写作:Qwen3.5-9B-AWQ-4bit实现图文内容生成

OpenClaw自动化写作:Qwen3.5-9B-AWQ-4bit实现图文内容生成 1. 为什么需要自动化图文创作 作为一个技术博主,我每周至少要产出3-4篇包含配图的技术文章。过去这个流程非常痛苦:先写完文章,再到Unsplash找配图,然后手动…...

解决Vivado中FDCP时序警告的实战技巧

1. 理解FDCP时序警告的本质 在Vivado开发过程中遇到FDCP时序警告时,很多开发者第一反应是"这又是个莫名其妙的警告"。但根据我处理过的二十多个类似案例,这个警告其实是个非常负责的"哨兵",它在提醒你电路可能存在严重的…...

基于CBLOF算法的用电异常用户识别:原理、实践与工程落地(上篇)

目录 摘要 关键词 一、引言:用电异常检测的业务痛点与技术挑战 1.1 传统阈值法的局限性 1.2 有监督学习方法的适配性不足 1.3 传统离群检测算法的不足 1.4 CBLOF算法的适配性优势 二、CBLOF算法核心原理深度剖析 2.1 算法核心流程(完整版) 步骤1:数据预处理 步骤…...

Jetson Orin NX 16G显存够用吗?实测同时跑4个YOLOv8模型(含姿态估计)的完整配置与性能分析

Jetson Orin NX 16G显存实战:多模型并发推理的性能极限测试 当我们需要在边缘设备上部署多个视觉模型时,硬件选型往往成为最令人头疼的问题。最近在为一个智能监控项目做技术验证时,我遇到了一个典型场景:需要在单台设备上同时运行…...

Qwen3.5-2B模型Java开发集成指南:SpringBoot微服务实战案例

Qwen3.5-2B模型Java开发集成指南:SpringBoot微服务实战案例 1. 为什么企业需要AI微服务化 电商平台的商品审核团队每天要处理数万张用户上传的图片,传统人工审核方式不仅效率低下,还容易因疲劳导致误判。某头部电商引入Qwen3.5-2B模型后&am…...

声音克隆新玩法:CosyVoice3教你融合多个音色生成独特声线

声音克隆新玩法:CosyVoice3教你融合多个音色生成独特声线 1. 引言:为什么需要声音融合技术 1.1 单一音色的局限性 在数字内容爆炸式增长的今天,声音克隆技术已经成为视频制作、有声读物、虚拟主播等领域的重要工具。然而,传统的…...

一人带多个数字帮手干活的新方式,人+智能体协同工作

现在上班干活,多了种新方式 —— 人带着智能体一起干,说白了就是给自己配几个不用休息的数字小帮手,你管定方向、做决策,它们管跑腿、做杂活,一起把活干得又快又好。 这种协作一点都不复杂,核心就俩字&…...

JBoltAI V4.2 使用体验 这些优化更贴合实际需求

从 JBoltAI 框架 4.1 版本用到 4.2 版本,能明显感受到这次升级都是围绕实际使用中的痛点做的优化,没有花哨的功能,全是提升操作便捷性、完善内容处理能力的实用更新,不管是日常简单使用还是处理各类工作内容,体验都顺畅…...