TypeScript的知识梳理

1、为什么使用typescript?

1)LSP Language Server Protocol语言服务器协议,编译时提前暴露错误

2)统一代码规范,风格和质量

3)解决业务工单问题,研发联调问题(前后端联调参数问题明确)

2、typescript

1)TS是编译时强类型的静态语言,编译时任何错误在编译时发现,不像js在运行时候确定

2)浏览器和nodejs并不能直接识别TS代码,需要编译成js代码

3)静态类型:类型是在编写代码的时候指定的,不是在js中在运行时确定的

4)强类型:有严格的类型检查,并且有类型标注

3、类型标注

1)注意首字母小写

TypeScript 复制代码
let v1:number = 1;
let v2:string = 'hello';
let v3:boolean = true;
let v4:null = null;
let v5:undefined = undefined;

4、类型推断

TypeScript 复制代码
let v5 = 10;
v5 = 'hello'; // TS里面这样写会提示异常

// 如果希望像js一样,赋值任意类型,可以使用any标注
let v6: any = 123;
v6 = 'hello';

如果进行类型推断,直接给变量赋值null或者undefined,默认类型是any

typescript环境的安装:

1、假设当前的执行环境是dom

2、如果代码中没有使用模块化语句(import/export),默认该代码是全局执行

3、编译的目标代码是ES3

修改以上假设的方式:

1、使用tsc命令行的时候,加上选项参数

2、在tsconfig.json中设置编译选项

TS里面配置文件

1、项目里面创建tsconfig.json

2、tsc --init命令行会在当前目录下创建tsconfig.json文件

compileOptions选项:编译选项

1、target:编译目标版本,默认是ES3,可以修改的(es2016)

2、module:模块化方案,默认是none,可以修改的(commonjs/es6)

3、lib:编译时引入的库文件,默认是dom和es5,可以修改的(es2016)

4、types:编译时引入的类型声明文件,默认是node,可以修改的(@types/node/@types/jquery)

5、outDir:编译输出目录,默认是当前目录,可以修改的(dist)

include和exclude选项:包含和排除文件

1、include:包含文件,默认是当前目录下的所有ts文件,可以修改的(src/**/*)

2、exclude:排除文件,默认是node_modules和bower_components,可以修改的(dist/**)

files选项:指定要编译的文件,默认是当前目录下的所有ts文件,可以修改的(src/index.ts)

@types:是第三方库的类型声明文件,安装之后就可以在ts文件中使用该库了

@types/node:是node环境的类型声明文件,安装之后就可以在ts文件中使用node环境的全局变量了

添加配置文件之后,tsc命令后面就不可以跟文件名了,有的话也会忽略掉

第三方库:

ts-node:将ts代码在内存中完成编译,同时完成运行(npm i -g ts-node)ts-node src/index.ts

nodemon:监视文件变化,自动重启(npm i -g nodemon)nodemon --exec "ts-node src/index.ts"

相关推荐
一点一木7 小时前
深度体验TRAE SOLO移动端7天:作为独立开发者,我把工作流揣进了兜里
前端·人工智能·trae
天外飞雨道沧桑8 小时前
TypeScript 中 omit 和 record 用法
前端·javascript·typescript
Lee川8 小时前
mini-cursor 揭秘:从 Tool 定义到 Agent 循环的完整实现
前端·人工智能·后端
canonical_entropy9 小时前
从 Spec-Driven Development 到 Attractor-Guided Engineering
前端·aigc·ai编程
研☆香9 小时前
聊聊前端页面的三种长度单位
前端
给钱,谢谢!9 小时前
React + PixiJS 实现果园成长页:从状态机到浇水动画
前端·react.js·前端框架
暗冰ཏོ11 小时前
VUE面试题大全
前端·javascript·vue.js·面试
次元工程师!11 小时前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
Bug-制造者12 小时前
现代Web应用全栈开发:从架构设计到部署落地实战
前端
青春喂了后端12 小时前
IntelliGit 前端状态层重构:把一个全局 Store 拆成清晰的状态边界
前端·重构·状态模式