TypeScript - 利用GPT辅助学习

TypeScript

    • 一、基础
      • 1. 安装 TypeScript
      • 2. 创建你的第一个 TypeScript 文件
      • 3. 编译 TypeScript 代码
      • 4. 变量声明与类型注解
      • 5. 函数与类型注解
      • 6. 总结
    • 二、进阶
      • 常用类型
        • 1. 类型别名
        • 2. 对象类型
        • 3. 类型断言
        • 4.`typeof` 操作符
      • 高级类型
        • 1. 类
        • 2. 交叉类型
        • 3. 泛型与 `keyof`
        • 4. 索引签名类型与 索引查询类型
        • 5 映射类型
        • 6.总结
    • 三、文件类型
      • 1. `.ts` 文件 — TypeScript 的“主战场”
        • 用途:编写程序代码的地方。
        • 示例:
      • 2. `.d.ts` 文件 — 类型声明的超级英雄
        • 用途:为 JS 提供类型信息
        • 示例:
      • 3.`.ts` 与 `.d.ts` 文件的关键区别
      • 4.如何使用 `.d.ts` 文件
      • 5.总结:TS 里的 `.ts` 和 `.d.ts` 文件

本篇由GPT辅助学习TypeScript而来的,仅为简单学习所创,若有疑惑还请去 TypeScript官网进一步了解

一、基础

1. 安装 TypeScript

在开始之前,你需要在你的电脑上安装 TypeScript 编译器。只需要几个步骤,就能拥有它。

步骤 1:安装 Node.js 和 npm 如果你还没有安装 Node.js,快去官网下载安装。Node.js 附带的 npm(包管理器)是我们接下来安装 TypeScript 的工具。

步骤 2:通过 npm 安装 TypeScript

npm install -g typescript

这样就将 TypeScript 安装到了你的机器上。-g 表示全局安装,可以在任何地方使用 tsc 命令。

步骤 3:检查安装是否成功

安装完后,输入以下命令检查 TypeScript 版本:

tsc --version

如果看到版本号,就表示安装成功!🎉


2. 创建你的第一个 TypeScript 文件

步骤 1:创建文件

用你喜欢的文本编辑器(如 VS Code、Sublime Text 等),创建一个文件,命名为 hello.ts。这个 .ts 后缀标志着这是一个 TypeScript 文件。

步骤 2:编写代码

hello.ts 文件里,写一些简单的 TypeScript 代码:

let message: string = "Hello, TypeScript!";
console.log(message);

3. 编译 TypeScript 代码

在命令行中,切换到包含 hello.ts 的目录,然后运行以下命令将 TypeScript 代码编译成 JavaScript:

tsc hello.ts

运行后,你会看到同目录下生成了一个 hello.js 文件,内容类似这样:

var message = "Hello, TypeScript!";
console.log(message);

步骤 3:运行 JavaScript 代码

你可以使用 Node.js 来运行编译后的 JavaScript 文件:

node hello.js

你应该会看到控制台输出:

Hello, TypeScript!

4. 变量声明与类型注解

在 TypeScript 中,变量的类型不再是模糊不清的了。你可以在声明变量时指定它们的类型。这是 TypeScript 的超级武器之一!

基本类型

let age: number = 30; // 数字类型
let names: string = "TypeScript"; // 字符串类型
let isActive: boolean = true; // 布尔类型

数组

数组的类型可以用 [] 来表示:

let numbers: number[] = [1, 2, 3]; // 数字数组
let fruits: string[] = ["apple", "banana", "cherry"]; // 字符串数组

或者使用 Array<type>

let numbers: Array<number> = [1, 2, 3];

元组

元组是一个固定长度和类型的数组:

let person: [string, number] = ["Alice", 25]; // 元组,第一个元素是字符串,第二个是数字

任意类型

有时候,你不确定变量的类型,可以使用 any 来表示:

let anything: any = "Hello"; // 类型可以是任何类型
anything = 42; // 现在是数字了
anything = true; // 现在是布尔类型了

字面量

用于约束变量的值为特定字符串、数字或布尔值的类型。

let direction: "up" | "down" = "up"; // 只能是 "up" 或 "down"
direction = "down"; // OK
direction = "left"; // 错误:不能赋值 "left"

枚举类型(Enums)

枚举用于定义一组具名的常数,通常用于表示一组有限的状态或选项。

enum Direction {Up = "UP",Down = "DOWN",Left = "LEFT",Right = "RIGHT",
}let move: Direction = Direction.Up;  // 使用枚举

未知类型

如果你想声明一个不确定的变量类型,但又想要一些检查,可以使用 unknown,它比 any 更安全:

let value: unknown = "hello";
value = 42; // 也可以是数字

5. 函数与类型注解

函数也可以定义参数类型和返回类型。这就是 TypeScript 的类型检查功能,能提前警告你代码中的潜在问题。

函数声明

function greet(name: string): string {return `Hello, ${name}!`;
}let greeting = greet("TypeScript");
console.log(greeting); // 输出 "Hello, TypeScript!"

可选参数

你也可以设置参数为可选的,只需要在参数后加一个问号:

function greet(name: string, age?: number): string {if (age) {return `Hello, ${name}! ${age} `;}return `Hello, ${name}!`;
}console.log(greet("Alice")); // 输出 "Hello, Alice!"
console.log(greet("Bob", 18)); // 输出 "Hello, Bob! 18"

6. 总结

你现在已经有了一个 TypeScript 文件,成功安装了 TypeScript 编译器,并了解了如何声明变量、定义类型和编写简单的函数。是不是感觉有点厉害了?😎

接下来,你可以探索更多高级功能,如 类、接口、泛型、模块 等等,但今天我们就先从基础开始,让你顺利地飞起来!🚀

二、进阶

让我们继续扩展 TypeScript 的神奇世界,一口气包括更多常用类型、类型别名、函数类型、对象类型等,也涵盖一些高级类型,让你的 TypeScript 技能更上一层楼。准备好了吗?我们开始!🚀

常用类型

1. 类型别名

类型别名(Type Aliases)用来给一个类型取个别名,可以让你的代码更简洁易懂。

type StringOrNumber = string | number;  // String 或 Number 类型
let data: StringOrNumber = "hello";  // 可以是 string 或 number
data = 42;  // 也可以是数字
2. 对象类型

对象类型(Object Types)是用来描述对象的结构,确保对象中的每个属性都有合适的类型。

type Person = {name: string;age: number;
};const person: Person = {name: "Alice",age: 30,
};
let person:{name: string;age: number;} ={name: "Alice",age: 30,
}
3. 类型断言

类型断言(Type Assertions)告诉 TypeScript 编译器,开发者“知道”某个变量的确切类型,通常用于从更宽泛的类型转换为更精确的类型。

let message: any = "Hello, TypeScript!";
let strLength: number = (message as string).length;  // 类型断言为 string
4.typeof 操作符

typeof 用于获取变量的类型,通常用于与 类型保护类型推论 配合使用。

let name = "Alice";
let nameType: typeof name = "Bob";  // 类型为 string

高级类型

1. 类

类(Class)是面向对象编程的重要组成部分,TypeScript 中的类提供了更多的功能和类型检查。

class Animal {name: string;constructor(name: string) {this.name = name;}speak() {console.log(`${this.name} makes a sound.`);}
}class Dog extends Animal {speak() {console.log(`${this.name} barks.`);}
}const dog = new Dog("Buddy");
dog.speak(); // 输出 "Buddy barks."

在 TypeScript 中,两个类型如果结构相同,它们是兼容的。

interface Animal {name: string;
}class Dog {name: string;constructor(name: string) {this.name = name;}
}let dog: Dog = new Dog("Buddy");
let animal: Animal = dog;  // 兼容,因为 Dog 类符合 Animal 接口的结构
2. 交叉类型

交叉类型(Intersection Types)是将多个类型合并为一个类型,合并后的类型包含了所有类型的成员。

type Person = {name: string;age: number;
};type Employee = {jobTitle: string;
};type EmployeePerson = Person & Employee; // 交叉类型const employee: EmployeePerson = {name: "Alice",age: 30,jobTitle: "Developer",
};
3. 泛型与 keyof

泛型(Generics)允许你定义可以接受任意类型的函数、类、接口等,确保类型安全。

function identity<T>(arg: T): T {return arg;
}let result = identity<string>("Hello!");  // 类型是 string
let numResult = identity<number>(42);  // 类型是 number

keyof 用来提取某个对象的所有键,并形成一个类型。

interface Person {name: string;age: number;
}type PersonKeys = keyof Person;  // "name" | "age"
4. 索引签名类型与 索引查询类型

索引签名类型(Index Signature Types) 允许你定义可以动态访问的对象类型。

interface Dictionary {[key: string]: string;
}const dict: Dictionary = {hello: "world",foo: "bar",
};

索引查询类型(Index Access Types) 允许你查询对象类型的某个属性的类型。

type NameType = Person["name"];  // 类型是 string
5 映射类型

映射类型(Mapped Types)允许你根据某个类型创建一个新类型,常用于批量修改对象的属性。

type ReadOnly<T> = {readonly [K in keyof T]: T[K];
};interface Person {name: string;age: number;
}const person: ReadOnly<Person> = { name: "Alice", age: 30 };
// person.name = "Bob";  // 错误,属性是只读的

也可以结合 in 操作符来创建新的类型。

type PartialPerson = {[K in keyof Person]?: Person[K];  // 将 Person 中的所有属性变为可选
};

6.总结

现在你已经有了 TypeScript 的常用类型、类型别名、函数类型、对象类型等的全面了解,还可以更深入地理解高级类型如类、交叉类型、泛型、映射类型等。通过这些强大的特性,TypeScript 能够帮助你编写更加灵活、安全且可维护的代码。是不是已经迫不及待要开始动手写更复杂的 TypeScript 项目了呢?🎉

三、文件类型

TypeScript 是个聪明的小家伙,它通过 .ts.d.ts 两种文件类型让我们编写代码时更加得心应手!让我们一个个捋顺清楚,看看它们之间的“微妙”区别吧!🚀


1. .ts 文件 — TypeScript 的“主战场”

.ts 文件就是 TypeScript 的本体,里面包含了你写的所有实现代码。你写的函数、类、变量,甚至所有的类型注解都在这里。可以说它是 TypeScript 的灵魂,是我们“战斗”的地方!💥

用途:编写程序代码的地方。
  • 你最常用的文件类型——这里写代码!
  • 可以写任何可执行的 TypeScript 代码——函数、类、对象、你想要的一切都在这里!
  • 编译成 JavaScript,跑在浏览器或 Node.js 环境中。🎯
示例:
// hello.ts — 你开始写的第一行 TypeScript 代码!🎉function greet(name: string): string {return `Hello, ${name}!`;  // 就这么简单,带着热情!
}console.log(greet("Alice"));  // 输出: Hello, Alice!

小贴士

  • 运行 tsc hello.ts 之后,你会发现编译器生成了 hello.js 文件,这个文件就是最终执行的 JavaScript 代码。
  • 你可以通过 node hello.js 来运行它,看看效果如何!🌟

2. .d.ts 文件 — 类型声明的超级英雄

.d.ts 文件就像是 TypeScript 的“隐形助手”——它不会参与执行,但却能让你的代码在幕后更有条理。它专门用来给你的 JavaScript 提供类型信息,帮助 TypeScript 理解“这个东西应该是什么类型”!😎

用途:为 JS 提供类型信息
  • 为外部库(那些没有内置 TypeScript 类型的 JavaScript 库)提供类型定义。👑
  • 你可以用它来描述 JavaScript 代码的结构,确保 TypeScript 编译器能够正确识别并提供类型检查。📚
  • 不包含实际实现代码,只是类型的“地图”。✨
示例:

假设你在用某个 JavaScript 库,里面有个 greet 函数,但它没有 TypeScript 类型信息。怎么办?没关系,来个 .d.ts 文件吧!

// greet.d.ts — 类型定义开始!declare function greet(name: string): string;  // 只定义函数签名,没有实现!

这个 .d.ts 文件告诉 TypeScript:“嘿,greet 函数是存在的,而且它接受一个字符串参数并返回一个字符串!”这样 TypeScript 就能通过这个类型信息来为你提供智能提示和类型检查了!✨


3..ts.d.ts 文件的关键区别

特性.ts 文件.d.ts 文件
目的编写 TypeScript 可执行代码,编译成 JavaScript 运行提供类型声明,告诉 TypeScript 其他代码的结构和类型
内容包含实现代码(函数、类、逻辑等)仅包含类型定义,没有实现代码
编译编译成 .js 文件不编译成 JavaScript 文件,仅用于类型检查
场景编写程序的核心逻辑、功能等为第三方库提供类型定义,或为 JavaScript 代码添加类型定义

4.如何使用 .d.ts 文件

  1. 为第三方库添加类型定义

你在使用一个没有 TypeScript 类型定义的 JavaScript 库时,怎么办?别担心!只需要通过 @types 包来引入它们的类型声明文件!🎉

举个例子,如果你在用 Lodash(一个 JavaScript 的工具库),并且想用它的类型定义:

npm install @types/lodash

这个命令会安装 Lodash 的类型声明文件,TypeScript 就会知道 Lodash 是怎样工作的,让你享受到类型检查和代码补全的好处!👏

手动为 JavaScript 写声明文件

如果你自己有一些 JavaScript 文件,也可以自己写 .d.ts 文件来为它们添加类型信息。比如你写了一个 utils.js 文件,你可以写一个 utils.d.ts 来描述它的类型:

// utils.d.tsdeclare function formatDate(date: Date): string;  // 格式化日期的函数
declare function sum(a: number, b: number): number;  // 加法函数MyButton: typeof MyButton;

这样 TypeScript 就知道了 formatDatesum 函数的类型,不用再怕类型错误了!💪


5.总结:TS 里的 .ts.d.ts 文件

  • .ts 文件:你的主战场,里面的代码会被编译为 JavaScript 并运行。它包含了你所有的功能实现,类型注解,甚至你的勇气!🚀
  • .d.ts 文件:类型声明的超级英雄,它让 TypeScript 知道其他 JavaScript 文件的类型结构,确保你的代码在没有实际实现的情况下也能进行类型检查。🦸‍♂️

这两种文件的结合,让 TypeScript 能够发挥最大的优势,既保证代码的灵活性,又确保类型安全。记住,.ts 文件用来写逻辑,.d.ts 文件用来给外部代码“写传单”!😏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/4928.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言内存之旅:从静态到动态的跨越

大家好&#xff0c;这里是小编的博客频道 小编的博客&#xff1a;就爱学编程 很高兴在CSDN这个大家庭与大家相识&#xff0c;希望能在这里与大家共同进步&#xff0c;共同收获更好的自己&#xff01;&#xff01;&#xff01; 本文目录 引言正文一 动态内存管理的必要性二 动态…

气膜料仓:工业仓储的高效与安全新选择—轻空间

在工业仓储领域&#xff0c;如何实现高效、安全、环保的存储方式成为企业关注的重点。气膜料仓以其独特的无梁无柱设计和智能化功能&#xff0c;为工业仓储带来了全新的解决方案。 空间利用率高&#xff1a;无障碍的大容量仓储 气膜料仓内部无梁无柱&#xff0c;形成了完全开…

Windows FileZila Server共享电脑文件夹 映射21端口外网连接

我有这样一个使用场景&#xff0c;在外部网络环境下&#xff0c;通过手机便捷地读取存储在电脑上的视频文件。比如在外出旅行、出差&#xff0c;身边没有携带电脑&#xff0c;仅依靠手机设备&#xff0c;就能随时获取电脑里存储的各类视频&#xff0c;无论是学习资料视频、工作…

CentOS部署FastDFS+Nginx并实现远程访问本地服务器中文件

文章目录 前言1. 本地搭建FastDFS文件系统 1.1 环境安装1.2 安装libfastcommon1.3 安装FastDFS1.4 配置Tracker1.5 配置Storage1.6 测试上传下载1.7 与Nginx整合1.8 安装Nginx1.9 配置Nginx 2. 局域网测试访问FastDFS3. 安装cpolar内网穿透4. 配置公网访问地址5. 固定公网地址…

2023年江西省职业院校技能大赛网络系统管理赛项(Linux部分样题)

一、Linux项目任务描述 你作为一个Linux的技术工程师,被指派去构建一个公司的内部网络,要为员工提供便捷、安全稳定内外网络服务。你必须在规定的时间内完成要求的任务,并进行充分的测试,确保设备和应用正常运行。任务所有规划都基于Linux操作系统,请根据网络拓扑、基本配…

【Spring】定义的Bean缺少隐式依赖

问题描述 初学 Spring 时&#xff0c;我们往往不能快速转化思维。例如&#xff0c;在程序开发过程中&#xff0c;有时候&#xff0c;一方面我们把一个类定义成 Bean&#xff0c;同时又觉得这个 Bean 的定义除了加了一些 Spring 注解外&#xff0c;并没有什么不同。所以在后续使…

使用Chrome和Selenium实现对Superset等私域网站的截图

最近遇到了一个问题&#xff0c;因为一些原因&#xff0c;我搭建的一个 Superset 的 Report 功能由于节假日期间不好控制邮件的发送&#xff0c;所以急需一个方案来替换掉 Superset 的 Report 功能 首先我们需要 Chrome 浏览器和 Chrome Driver&#xff0c;这是执行数据抓取的…

vulnhub靶场【IA系列】之Tornado

前言 靶机&#xff1a;IA-Tornado&#xff0c;IP地址为192.168.10.11 攻击&#xff1a;kali&#xff0c;IP地址为192.168.10.2 都采用虚拟机&#xff0c;网卡为桥接模式 本文所用靶场、kali镜像以及相关工具&#xff0c;我放置在网盘中&#xff0c;可以复制后面链接查看 htt…

不用编程即可实现多台PLC的MQTT协议JSON文件发布与订阅的智能网关的配置说明

IGT-SER系列智能网关支持各种PLC的以太网和串口协议&#xff0c;以及Modbus、OPC通讯&#xff0c;通过网关所带的参数配置工具软件&#xff0c;不用编程&#xff0c;即可打包和解析JSON格式的设备数据&#xff0c;通过MQTT、HTTP等协议发布和订阅。相关案例 IGT-SER系列智能网关…

为什么相关性不是因果关系?人工智能中的因果推理探秘

目录 一、背景 &#xff08;一&#xff09;聚焦当下人工智能 &#xff08;二&#xff09;基于关联框架的人工智能 &#xff08;三&#xff09;基于因果框架的人工智能 二、因果推理的基本理论 &#xff08;一&#xff09;因果推理基本范式&#xff1a;因果模型&#xff0…

ARCGIS国土超级工具集1.3更新说明

ARCGIS国土超级工具集V1.3版本&#xff0c;功能已增加至49 个。在V1.2的基础上修复了若干使用时发现的BUG&#xff0c;完善了部分已有的功能&#xff0c;新增了“面要素狭长面检测分割”等功能&#xff0c;新工具使用说明如下&#xff1a; 一、勘测定界工具栏更新土地分类面积表…

阿里云 Serverless 助力盟主直播:高并发下的稳定性和成本优化

在直播场景中&#xff0c;阿里云 Serverless 应用引擎 SAE 提供的无缝弹性伸缩与极速部署能力&#xff0c;确保直播间高并发时的流畅体验&#xff0c;降低了我们的运营成本&#xff0c;简化了运维流程。结合阿里云云原生数据库 PolarDB 的 Serverless 能力&#xff0c;实现了数…

网络编程 | UDP组播通信

1、什么是组播 在上一篇博客中&#xff0c;对UDP的广播通信进行了由浅入深的总结梳理&#xff0c;本文继续对UDP的知识体系进行探讨&#xff0c;旨在将UDP的组播通信由浅入深的讲解清楚。 组播是介于单播与广播之间&#xff0c;在一个局域网内&#xff0c;将某些主机添加到组中…

日历热力图,月度数据可视化图表(日活跃图、格子图)vue组件

日历热力图&#xff0c;月度数据可视化图表&#xff0c;vue组件 先看效果&#x1f447; 在线体验https://www.guetzjb.cn/calanderViewGraph/ 日历图简单划分为近一年时间&#xff0c;开始时间是 上一年的今天&#xff0c;例如2024/01/01 —— 2025/01/01&#xff0c;跨度刚…

使用nginx搭建通用的图片代理服务器,支持http/https/重定向式图片地址

从http切换至https 许多不同ip的图片地址需要统一进行代理 部分图片地址是重定向地址 nginx配置 主站地址&#xff1a;https://192.168.123.100/ 主站nginx配置 server {listen 443 ssl;server_name localhost;#ssl证书ssl_certificate ../ssl/ca.crt; #私钥文件ssl_ce…

WPS数据分析000001

目录 一、表格的新建、保存、协作和分享 新建 保存 协作 二、认识WPS表格界面 三、认识WPS表格选项卡 开始选项卡 插入选项卡 页面布局选项卡 公式选项卡 数据选项卡 审阅选项卡 视图选项卡 会员专享选项卡 一、表格的新建、保存、协作和分享 新建 ctrlN------…

使用 HTML 开发 Portal 页全解析

前言 在当今数字化时代&#xff0c;网站作为企业和个人展示信息、提供服务的重要窗口&#xff0c;其重要性不言而喻。而 Portal 页&#xff0c;作为网站的核心页面之一&#xff0c;承担着引导用户、整合信息等关键任务。那么&#xff0c;如何使用 HTML 开发一个功能齐全、界面…

Spring Boot 项目启动报错 “找不到或无法加载主类” 解决笔记

一、问题描述 在使用 IntelliJ IDEA 开发基于 Spring Boot 框架的 Java 程序时&#xff0c;原本项目能够正常启动。但在后续编写代码并重建项目后&#xff0c;再次尝试运行却出现了 “错误&#xff1a;找不到或无法加载主类 com.example.springboot.SpringbootApplication” 的…

上位机工作感想-2024年工作总结和来年计划

随着工作年限的增增长&#xff0c;发现自己越来越不喜欢在博客里面写一些掺杂自己感想的东西了&#xff0c;或许是逐渐被工作逼得“成熟”了吧。2024年&#xff0c;学到了很多东西&#xff0c;做了很多项目&#xff0c;也帮别人解决了很多问题&#xff0c;唯独没有涨工资。来这…

ChatGPT被曝存在爬虫漏洞,OpenAI未公开承认

OpenAI的ChatGPT爬虫似乎能够对任意网站发起分布式拒绝服务&#xff08;DDoS&#xff09;攻击&#xff0c;而OpenAI尚未承认这一漏洞。 本月&#xff0c;德国安全研究员Benjamin Flesch通过微软的GitHub分享了一篇文章&#xff0c;解释了如何通过向ChatGPT API发送单个HTTP请求…