TypeScript不是一门新的语言,而是ES6的超集。
TypeScript相对于ES5有五大改善
- 类型
- 类
- 注解
- 模块导入
- 语言工具包(比如,解构)
TypeScript相对于ES6新增两个功能:
- 类型检测
- 注解
1、类型
缺乏类型检查是JavaScript这些弱类型语言的特点,但是类型检查的好处有:
(1)有助于代码的编写,因为它可以在代码初期预防bug;
(2)有助于代码的阅读,因为它能清晰地表明你的意图。
TypeScript中的类型是可选的。
var name:string; function greetText(name:string):string{ return "hello"+name; }
内置类型:
- 字符串
- 数字
- 布尔类型
- 数组
- 枚举
枚举类型是一组可命名数值的集合,比如我们想要拿到某人的一系列角色
enum Role {Employee,Manager,Admin}; var role:Role=Role.Employee;
- 任意类型
如果没有为变量指定类型,那他的默认类型就是any
- “无”类型
2、对象的类型--接口
定义接口允许您检查变量组合以确保他们使用一致,然后当定义一个具有“Tom”接口所需的所有属性的对象时,将自动推断出类型。
export interface Person{ label: string; disabled: boolean; position?: string; }
var tom:Person={
label:"123",
diasbled:true
}
定义的变量属性比接口少一些属性或多一些属性是不允许的,如果不确定是否存在的属性,用“?”标识为可选属性。如:position?: string;
3、注解
注解(装饰器)是一类特殊类型的声明,可以用在类、方法、构造器、属性和参数上。