前端TypeScript高级技巧:让你的代码更安全

前端TypeScript高级技巧:让你的代码更安全

毒舌时刻

前端TypeScript?这不是增加工作量吗?

"JavaScript就够了,为什么要用TypeScript"——结果类型错误频发,调试困难,
"TypeScript太严格了,我写起来很麻烦"——结果代码质量差,维护困难,
"我只在关键地方用TypeScript,其他地方用any"——结果失去了TypeScript的意义。

醒醒吧,TypeScript不是负担,而是提高代码质量的利器!

为什么你需要这个?

  • 类型安全:在编译时发现类型错误
  • 代码提示:提供更好的IDE智能提示
  • 重构安全:重构代码时更加安全
  • 可读性:代码更加清晰易懂
  • 可维护性:减少运行时错误,提高代码可维护性

反面教材

// 反面教材:过度使用any function processData(data: any) { // 没有类型检查,容易出错 return data.name.toUpperCase(); } // 反面教材:类型定义不完整 interface User { id: number; name: string; // 缺少email等其他属性 } // 反面教材:类型断言滥用 function getUser(id: number): User { // 不安全的类型断言 return fetch(`/api/users/${id}`).then(res => res.json()) as unknown as User; } 

正确的做法

// 正确的做法:使用泛型 function identity<T>(arg: T): T { return arg; } // 使用泛型约束 interface Lengthwise { length: number; } function loggingIdentity<T extends Lengthwise>(arg: T): T { console.log(arg.length); return arg; } // 正确的做法:使用联合类型和类型守卫 type Shape = Circle | Square; interface Circle { kind: 'circle'; radius: number; } interface Square { kind: 'square'; sideLength: number; } function getArea(shape: Shape): number { // 类型守卫 if (shape.kind === 'circle') { return Math.PI * shape.radius ** 2; } else { return shape.sideLength ** 2; } } // 正确的做法:使用类型推断 const user = { id: 1, name: '张三', email: '[email protected]' }; // TypeScript会自动推断user的类型 // 正确的做法:使用映射类型 interface Person { name: string; age: number; } // 生成只读类型 type ReadonlyPerson = Readonly<Person>; // 生成可选类型 type PartialPerson = Partial<Person>; // 生成必填类型 type RequiredPerson = Required<PartialPerson>; // 正确的做法:使用条件类型 // 提取Promise的返回类型 type UnwrapPromise<T> = T extends Promise<infer U> ? U : T; // 测试 async function fetchData(): Promise<string> { return 'data'; } // 类型会被推断为string let data: UnwrapPromise<ReturnType<typeof fetchData>>; // 正确的做法:使用模板字面量类型 type EventName<T extends string> = `${T}Changed`; type MouseEventName = EventName<'click' | 'mouseover' | 'mouseout'>; // 类型为 'clickChanged' | 'mouseoverChanged' | 'mouseoutChanged' // 正确的做法:使用类型别名和接口 // 类型别名 type UserID = number; type UserName = string; type Email = string; // 接口 interface User { id: UserID; name: UserName; email: Email; createdAt: Date; updatedAt: Date; } // 正确的做法:使用枚举 enum Role { Admin = 'admin', User = 'user', Guest = 'guest' } function checkPermission(role: Role): boolean { return role === Role.Admin; } // 正确的做法:使用命名空间 namespace Validation { export interface StringValidator { isAcceptable(s: string): boolean; } const lettersRegexp = /^[A-Za-z]+$/; const numberRegexp = /^[0-9]+$/; export class LettersOnlyValidator implements StringValidator { isAcceptable(s: 

Read more

前端老铁必看:Mock劫持Ajax翻车实录与避坑指南

前端老铁必看:Mock劫持Ajax翻车实录与避坑指南

前端老铁必看:Mock劫持Ajax翻车实录与避坑指南 * 前端老铁必看:Mock劫持Ajax翻车实录与避坑指南 * 咱就是说,这玩意儿到底咋忽悠浏览器的 * 核心原理:浏览器里的"替身演员" * 那fetch呢?它也跑不掉 * url、rtype、template这三个参数到底咋配合的 * 匹配优先级:谁说了算 * 扒开源码看底裤,拦截逻辑其实是这么玩的 * 源码级别的URL匹配骚操作 * 请求类型(rtype)的判断陷阱 * 数据生成引擎:template是怎么变成真实JSON的 * 延迟模拟:为什么要假装网络很慢 * 爽完之后的贤者时间:这招到底有啥毛病 * 性能陷阱:假数据太多,浏览器直接去世 * 类型安全地狱:TS项目里的Mock灾难 * 复杂业务逻辑模拟不了:鉴权、文件上传、流式数据 * 跨域和CORS的坑 * 真实搬砖场景:我在项目里是怎么靠它摸鱼的 * 场景一:后端接口延迟,先画UI * 场景二:模拟

深入探讨Web应用开发:从前端到后端的全栈实践

深入探讨Web应用开发:从前端到后端的全栈实践

目录   引言 1. Web应用开发的基本架构 2. 前端开发技术 HTML、CSS 和 JavaScript 前端框架与库 响应式设计与移动优先 3. 后端开发技术 Node.js(JavaScript后端) Python(Flask和Django) Ruby on Rails Java(Spring Boot) 4. 数据库选择与管理 关系型数据库(SQL) 非关系型数据库(NoSQL) 5. API设计与开发 RESTful API GraphQL 6. 测试与调试 单元测试 集成测试与E2E测试 7. 部署与运维 云服务平台 容器化与Docker CI/CD(持续集成与持续交付) 监控与日志 弹性伸缩与负载均衡 8.

Webots R2023b 完整安装配置教程

Webots R2023b 完整安装配置教程 声明:本教程由豆包、ChatGPT等AI工具协助完成。 本教程讲解如何安装 Python3、包管理器 Micromamba、必要依赖包(如 opencv-python),以及 Webots 仿真软件,并完成 Micromamba Python 环境与 MATLAB 地址的配置,适用于 Windows、macOS 双系统。 一、前置说明 1. 适用场景:需要使用 Webots 进行仿真开发,同时依赖 Python 进行脚本编写、OpenCV 进行图像处理,通过 Micromamba 管理 Python 环境,并关联 MATLAB 路径用于联合开发。 2. 版本约定(兼容性最优): * Python:

【JavaWeb12】数据交换与异步请求:JSON与Ajax的绝妙搭配是否塑造了Web的交互革命?

【JavaWeb12】数据交换与异步请求:JSON与Ajax的绝妙搭配是否塑造了Web的交互革命?

文章目录🌍一. 数据交换--JSON❄️1. JSON介绍❄️2. JSON 快速入门❄️3. JSON 对象和字符串对象转换❄️4. JSON 在 java 中使用❄️5. 代码演示🌍二. 异步请求--Ajax❄️1. 基本介绍❄️2. JavaScript 原生 Ajax 请求❄️3. JQuery 的 Ajax 请求🌍三. 线程数据共享和安全 -ThreadLocal❄️1. ThreadLocal基本介绍❄️2. 源码分析 🙋‍♂️ 作者:@whisperrr.🙋‍♂️ 👀 专栏:JavaWeb👀 💥 标题:【JavaWeb12】数据交换与异步请求:JSON与Ajax的绝妙搭配是否塑造了Web的交互革命?💥 ❣️ 寄语:比较是偷走幸福的小偷❣️ 前言: