- UID
- 677087
- 積分
- 0
- 金币
- 0
- 精華
- 0
- 威望
- 0
- 贡献
- 0
- 閲讀權限
- 220
- 註冊時間
- 2012-6-6
- 最後登錄
- 2026-5-6
- 在線時間
- 0 小時
热心网友
- 金币
- 0
- 閲讀權限
- 220
- 精華
- 0
- 威望
- 0
- 贡献
- 0
- 在線時間
- 0 小時
- 註冊時間
- 2012-6-6
|
第一章 快速入门
0、TypeScript简介
- TypeScript是JavaScript的超集。
- 它对JS进行了扩展,向JS中引入了类型的概念,并添加了许多新的特性。
- TS代码需要通过编译器编译为JS,然后再交由JS解析器执行。
- TS完全兼容JS,换言之,任何的JS代码都可以直接当成JS使用。
- 相较于JS而言,TS拥有了静态类型,更加严格的语法,更强大的功能;TS可以在代码执行前就完成代码的检查,减小了运行时异常的出现的几率;TS代码可以编译为任意版本的JS代码,可有效解决不同JS运行环境的兼容问题;同样的功能,TS的代码量要大于JS,但由于TS的代码结构更加清晰,变量类型更加明确,在后期代码的维护中TS却远远胜于JS。
1、TypeScript 开发环境搭建
-
下载Node.js
- 64位:https://nodejs.org/dist/v14.15.1/node-v14.15.1-x64.msi
- 32位:https://nodejs.org/dist/v14.15.1/node-v14.15.1-x86.msi
-
安装Node.js
-
使用npm全局安装typescript
- 进入命令行
- 输入:npm i -g typescript
-
创建一个ts文件
-
使用tsc对ts文件进行编译
-
进入命令行
-
进入ts文件所在目录
-
执行命令:tsc xxx.ts
2、基本类型
-
类型声明
-
类型声明是TS非常重要的一个特点
-
通过类型声明可以指定TS中变量(参数、形参)的类型
-
指定类型后,当为变量赋值时,TS编译器会自动检查值是否符合类型声明,符合则赋值,否则报错
-
简而言之,类型声明给变量设置了类型,使得变量只能存储某种类型的值
-
语法:
-
自动类型判断
- TS拥有自动的类型判断机制
- 当对变量的声明和赋值是同时进行的,TS编译器会自动判断变量的类型
- 所以如果你的变量的声明和赋值时同时进行的,可以省略掉类型声明
-
类型:
| 类型 |
例子 |
描述 |
| number |
1, -33, 2.5 |
任意数字 |
| string |
'hi', "hi", hi |
任意字符串 |
| boolean |
true、false |
布尔值true或false |
| 字面量 |
其本身 |
限制变量的值就是该字面量的值 |
| any |
* |
任意类型 |
| unknown |
* |
类型安全的any |
| void |
空值(undefined) |
没有值(或undefined) |
| never |
没有值 |
不能是任何值 |
| object |
|
任意的JS对象 |
| array |
[1,2,3] |
任意JS数组 |
| tuple |
[4,5] |
元素,TS新增类型,固定长度数组 |
| enum |
enum |
枚举,TS中新增类型 |
-
number
-
boolean
-
string
-
字面量
-
any
-
unknown
-
void
-
never
-
object(没啥用)
-
array
-
let list: number[] = [1, 2, 3];
let list: Array<number> = [1, 2, 3];
-
tuple
-
enum
-
enum Color {
Red,
Green,
Blue,
}
let c: Color = Color.Green;
enum Color {
Red = 1,
Green,
Blue,
}
let c: Color = Color.Green;
enum Color {
Red = 1,
Green = 2,
Blue = 4,
}
let c: Color = Color.Green;
-
类型断言
3、编译选项
-
自动编译文件
-
自动编译整个项目
-
如果直接使用tsc指令,则可以自动将当前项目下的所有ts文件编译为js文件。
-
但是能直接使用tsc命令的前提时,要先在项目根目录下创建一个ts的配置文件 tsconfig.json
-
tsconfig.json是一个JSON文件,添加配置文件后,只需只需 tsc 命令即可完成对整个项目的编译
-
配置选项:
-
include
-
定义希望被编译文件所在的目录
-
默认值:["**/*"]
-
示例:
-
exclude
-
extends
-
files
4、webpack
5、Babel
来源:https://www.cnblogs.com/nlx123/p/16613606.html |
|