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

TypeScript简介

🌟 TypeScript入门

TypeScript 是 JavaScript 的超集,由微软开发并维护,通过静态类型检查现代语言特性,让大型应用开发变得更加可靠和高效。

// 一个简单的 TypeScript 示例
interface User {name: string;age: number;greet(): string;
}class Developer implements User {constructor(public name: string, public age: number) {}greet() {return `Hello, I'm ${this.name} and I code! 👨‍💻`;}
}const dev = new Developer("Alice", 28);
console.log(dev.greet());

🧩 为什么选择 TypeScript?

特性JavaScriptTypeScript
类型系统动态类型静态类型
编译时错误检查
IDE 智能提示有限强大
面向对象特性基本完整
适用项目规模中小型中大型

🎯 TypeScript 核心特性

1. 🔍 类型系统(静态类型检查)

let isDone: boolean = false;  // 布尔值
let decimal: number = 6;      // 数字
let color: string = "blue";   // 字符串
let list: number[] = [1, 2, 3]; // 数组// 元组
let tuple: [string, number] = ["hello", 10];// 枚举
enum Color { Red = 1, Green, Blue }
let c: Color = Color.Green;

2. 🏗️ 接口与类型别名

// 接口
interface Point {x: number;y: number;z?: number; // 可选属性readonly id: string; // 只读属性
}// 类型别名
type UserID = string | number;// 实现接口
class MyPoint implements Point {constructor(public x: number, public y: number, readonly id: string) {}
}

3. 🧬 泛型编程

function identity<T>(arg: T): T {return arg;
}// 使用
let output = identity<string>("myString");
let output2 = identity(42); // 类型推断

4. 🎭 高级类型

// 联合类型
type ID = string | number;// 交叉类型
type Named = { name: string };
type Aged = { age: number };
type Person = Named & Aged;// 类型守卫
function isString(test: any): test is string {return typeof test === "string";
}

🛠️ TypeScript 开发工具链

1. 开发环境配置

# 初始化项目
npm init -y# 安装 TypeScript
npm install typescript --save-dev# 初始化 tsconfig.json
npx tsc --init

2. 推荐 VSCode 插件

  • TypeScript Vue Plugin (Vue 支持)
  • ESLint (代码检查)
  • Prettier (代码格式化)
  • Jest Runner (测试运行)

3. 编译与运行

// tsconfig.json 示例
{"compilerOptions": {"target": "ES2020","module": "commonjs","strict": true,"esModuleInterop": true,"outDir": "./dist"},"include": ["src/**/*"]
}

🌈 TypeScript 5.0+ 新特性

1. 🔥 装饰器(标准)

@sealed
class Greeter {greeting: string;constructor(message: string) {this.greeting = message;}@loggreet() {return "Hello, " + this.greeting;}
}

2. 🚀 满足 ES 模块规范

// 支持顶级 await
const data = await fetchData();
console.log(data);

3. 🧠 更智能的类型推断

// 自动推断数组类型
const mixed = ["text", 42, true]; // (string | number | boolean)[]

📊 TypeScript 生态系统

框架/库TS 支持度特点
React✅ 优秀完整类型定义
Vue 3✅ 原生组合式 API 完美支持
Angular✅ 内置完全基于 TypeScript
Node.js✅ 良好@types/node 提供类型定义
Express✅ 良好需要安装 @types/express

🚧 常见问题与解决方案

1. 类型断言

// 方式一:尖括号语法
let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length;// 方式二:as 语法
let strLength2: number = (someValue as string).length;

2. 处理第三方库

// 没有类型定义的库
declare module "some-untyped-library";// 使用 @types
npm install --save-dev @types/lodash

3. 类型扩展

// 扩展全局类型
declare global {interface Window {myCustomProp: string;}
}

🎓 学习资源推荐

  1. 官方文档 - 最权威的参考资料
  2. TypeScript Deep Dive - 深入理解 TS
  3. TypeScript 入门教程 - 中文优质教程
  4. TypeScript 4.0 新特性 - 官方博客
http://www.xdnf.cn/news/4191.html

相关文章:

  • LeetCode 热题 100 198. 打家劫舍
  • 【机器学习-线性回归-6】机器学习中的维度:从特征工程到降维艺术
  • Missashe考研日记-day33
  • 数字政府大模型应用方案
  • MySQL 8.4.5 源码编译安装指南
  • 国联股份卫多多与国术科技签署战略合作协议
  • 使用OpenCV 和Dlib 实现表情识别
  • AI量化解析:从暴跌5%到飙涨3%—非线性动力学模型重构黄金极端波动预测框架
  • 人工智能如何革新数据可视化领域?探索未来趋势
  • 调用七牛云对象存储,附工具类
  • 多层PCB板的地层分割技巧有哪些?
  • Pytorch 的模型保存
  • 数据结构(一)——线性表的顺序表示和实现
  • k8s术语之service
  • k8s pod request/limit 值不带单位会发生什么?
  • 浅谈 - GPTQ为啥按列量化
  • NGINX `ngx_http_browser_module` 深度解析与实战
  • 螺杆支撑座:数控机床高效稳定运行的关键支撑
  • MYSQL的DDL语言和单表查询
  • 完全免费的PDF电子发票批量辅助打印工具
  • vue3+ts继续学习
  • js var a=如果ForRemove=true,是“normal“,否则为“bold“
  • 2025-05-06 事业-独立开发项目-记录
  • 软件代码签名证书SSL如何选择?
  • C++复习2
  • Spring Boot之MCP Client开发全介绍
  • 二叉树—中序遍历—非递归
  • 两数之和(暴力+哈希查找)
  • Linux[Makefile]
  • ffmpeg录音测试