TypeScript的主要特性
- 超集 :TypeScript 是 JavaScript 的一个超集。
- 类型系统 :正如其名,TypeScript在JavaScript的基础上,包装了类型机制,使其变身为静态类型语言。
- 编辑器功能 :增强了编辑器和IDE功能,包括代码补全、接口提示、跳转到定义、重构等。
- 错误提示 :可以在编译阶段就发现大部分错误,帮助调试程序。
JavaScript的特点
- JavaScript 是一种轻量级的解释性脚本语言。
- JavaScript 是弱类型、动态类型语言,允许隐式转换,只有运行时才能确定变量的类型。
超集
也就是说,你不是“不用JavaScript开发而改用TypeScript”了,本质上开发语言还是JavaScript,只是TypeScript在JavaScript的基础上扩展了新的特性,JavaScript该有的,TypeScript都有。
为什么TypeScript的静态类型能增强代码的可读性和可维护性
TypeScript通过类型注解提供编译时的静态类型检查。
编程语言可简单地看作对一系列变量的处理,变量从某个维度上讲是建立在类型系统上的,就像客观世界万物也是由各种类型组成。
首先是基础的类型,代表计量的数字类型,代表身份的字符串类型,代表逻辑是否的布尔类型,代表集合的对象(含数组),代表存在性的'空'。
然后是各种自定义的类型,某样生活用品、某种职业,即面向对象编程里的对象、类、接口的概念。
这也符和人对事物的普遍认知,从一个类型,就能大致知道它是什么、怎么能得到它、它能做什么,减少查阅、理解、校验的过程,最好的情况是无需将关注点转移……
最强大的地方还不在于基础类型的注解,而在于自定义类型(接口或类)、内置对象(HTMLElement,Event等)的提示。
以confirmAddFruits这个组件中方法和fruits.service这个服务层的函数为例。
1. 它是什么
以入参fruit为例:
- JavaScript
- 去fruits.service.js看看,它是http请求传给后端的参数,是个对象。
- 到接口文档看看。
- TypeScript
- 是个Fruit类型的对象。
- 操作编辑器能直接显示fruit含有id, name, isFresh属性,每个属性是什么类型。
2. 怎么能得到它:
以组件成员变量fruits为例:
- JavaScript
去data处看看,初始值是null(因为某些需要,初始值不能是[]),最多从命名推测应该是个数组,但数组是怎么构成的,还得回想或查一下model层、view层的设计。
- TypeScript
操作编辑器能直接显示fruits的类型是Fruit[],即Fruit类型的单项构成的数组,于是操作数组合并。
3. 它能做什么
this.fruitService.addFruit 是调用服务层的方法,它返回什么?
- JavaScript
去查接口文档
- TypeScript
返回 Observable<Fruit> ,订阅之,得到的数据是Fruit类型:一个水果。
// confirmAddFruits.js
export default {
data() {
return {
fruits: null,
isShowModal: false;
}
}
confirmAddFruit(fruit) {
this.fruitService.addFruit(fruit).then(fruit => {
this.fruits = \[fruit, ...this.fruits\];
this.isShowModal = false;
});
}
}
// confirmAddFruit.ts
interface Fruit {
id: number;
name: string;
isFresh: boolean
}
export class FruitsComponent {
fruits: Fruit\[\] = \[\];
isShowModal = false;
confirmAddFruit(fruit: Fruit): void {
this.fruitService.addFruit(fruit as Fruit).subscribe((fruit: Fruit) => {
this.fruits = \[fruit, ...this.fruits\];
this.isShowModal = false;
});
}
}
// fruits.service.js
function addFruit(fruit) {
// ...
}
// fruits.service.ts
function addFruit(fruit: Fruit): Observable<Fruit> {
// ...
}
可读性和可维护性
JavaScript所能做的
- 依靠编码规范,命名、注释(特别是类型的注释)。
- 对自己编写代码和维护他人代码的熟悉度。
- 编辑器的搜索、替换、重构等功能,代码提示、补全。(搜索替换易出错)
- 自动测试、手动测试。
- 运行错误的提示。
TypeScript所能做的
函数参数的传递是是最容易出错出bug的地方之一,有了类型注解,就能一目了然得知道需要传递什么样的参数,防止遗漏、误删。
引用类型数据相较于基本数据类型,数据的维护难度更大,有了接口定义,就不再混乱。
此外,在编译阶段的类型检查和错误提示,可以取代很多单元测试所需要的工作。
增强的编辑器功能
TypeScript提供了静态的代码分析,在编译之前,可以过滤掉大部分错误,而JS是无法做到的。
错误提示
随便举几个例子:
- 表单输入的数字,获取到的是字符串。
- 函数参数(尤其是数量)的检查。无论是输入时,还是编译时的检查。
- 最强大的不在于JS类型的提示,而在于自定义类型(接口或类)的提示。具体项的提示,编辑器中搞定,不用切换视口。
缺点
我几乎找不出TS有什么缺点。
唯一的就是:写类型定义会一定程度上降低开发效率,但是在大项目中可折衷进行,磨刀不误砍柴工。
最后的彩蛋
TypeScript最强大的应用场景:代码分支合并冲突解决、项目重构的安全保障。
类型系统符合人对事物的普遍认知,提供了强力的安全保障机制,智能提示大大提高代码编写效率!
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。