前端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

前端真的能防录屏?EME(加密媒体扩展) DRM 反录屏原理 + 实战代码

前端真的能防录屏?EME(加密媒体扩展) DRM 反录屏原理 + 实战代码

🌷 古之立大事者,不惟有超世之才,亦必有坚忍不拔之志 🎐 个人CSND主页——Micro麦可乐的博客 🐥《Docker实操教程》专栏以最新的Centos版本为基础进行Docker实操教程,入门到实战 🌺《RabbitMQ》专栏19年编写主要介绍使用JAVA开发RabbitMQ的系列教程,从基础知识到项目实战 🌸《设计模式》专栏以实际的生活场景为案例进行讲解,让大家对设计模式有一个更清晰的理解 🌛《开源项目》本专栏主要介绍目前热门的开源项目,带大家快速了解并轻松上手使用 🍎 《前端技术》专栏以实战为主介绍日常开发中前端应用的一些功能以及技巧,均附有完整的代码示例 ✨《开发技巧》本专栏包含了各种系统的设计原理以及注意事项,并分享一些日常开发的功能小技巧 💕《Jenkins实战》专栏主要介绍Jenkins+Docker的实战教程,让你快速掌握项目CI/CD,是2024年最新的实战教程 🌞《Spring Boot》专栏主要介绍我们日常工作项目中经常应用到的功能以及技巧,代码样例完整 👍《Spring Security》专栏中我们将逐步深入Spring Security的各个

基于开源飞控pix的无人机装调与测试

基于开源飞控pix的无人机装调与测试

文章目录 * 前言 * 硬件使用说明 * 一、Hyper982 RTK模块 * 作为移动站使用 * 通过串口助手设置RTK参数(移动站) * 设置飞控参数(ArduPilot) * 设置飞控参数(PX4) * 二、HyperLte 4G图数传 * 资源下载 * 1、地面站软件和固件可执行文件 * 超维定制版HyperQGC(推荐) * NTRIP功能使用方法 * 基于超维定制版QGC和ArduPilot固件的领航跟随编队 * 多路视频流设置 * MQTT设置 * 地面站设置 * 4G模块配置 * MQTT服务器配置 * 飞控配置 * 海康威视相机云台控制 * Mission Planner地面站 * PX4固件可执行文件 * ArduPilot固件可执行文件 * 2、安装好环境的虚拟机 * 安装虚拟机 *

Windows 下 Nginx 配置全指南:前端 Vue + 后端服务一体化部署

在现代 Web 开发中,前后端分离架构已成为主流。前端使用 Vue、React 等框架构建 SPA(单页应用),后端提供 RESTful API 服务。为了在本地或生产环境中高效部署这类应用,Nginx 是一个非常优秀的轻量级 Web 服务器和反向代理工具。 本文将手把手教你如何在 Windows 系统下下载、安装并配置 Nginx,实现: * 前端 Vue 项目的静态资源托管 * 后端 API 请求的反向代理(解决跨域) * 统一入口访问(如 http://localhost) 一、准备工作 1. 系统要求 * Windows 7 / 10 / 11 / Server 系列 * 已安装 Node.js(用于构建

Google AI Studio 全指南:从入门到精通 Gemini 开发

在生成式 AI 的浪潮中,Google 凭借 Gemini 模型系列强势反击。而对于开发者来说,想要体验、调试并集成 Gemini 模型,最佳的入口并不是 Google Cloud Vertex AI(那是企业级的),而是 Google AI Studio。 Google AI Studio 是一个基于 Web 的快速原型设计环境,它允许开发者极速测试 Gemini 模型,并将测试好的 Prompt(提示词)一键转换为代码。本文将带你从零开始,掌握这款强大的工具。 一、 什么是 Google AI Studio? Google AI Studio 是 Google 为开发者提供的免费(或低成本)AI