TypeScript 是 JavaScript 的超集,由微软公司在 2012 年正式发布。
环境搭建: npm install -g typescript
1、运行HelloWorld 新建demo1.ts并写入如下代码
data:image/s3,"s3://crabby-images/7b5fd/7b5fd6e6eff6efd7a4a7b221818e8fa2df5ffc53" alt=""
运行 node demo1.ts会报错
需运行 “tsc demo1.ts” 将ts文件转换为js文件,“node demo1.js”,即可打印HelloWorld。
或者安装可以运行ts的插件 npm install -g ts-node,安装后执行“ts-node xxx.ts”
2、静态类型
基础静态类型:“变量命名:类型” const count: number =1;
data:image/s3,"s3://crabby-images/e1bf0/e1bf057554db9516f7537c0fe251a040be335710" alt=""
3、函数定义
注解
类型注解(type annotation):常用于方法中,来定义参数类型,参见add
类型推断(type inferrence):ts会自动推断出one是数字类型 const one = 123
参数
可选参数 stature?: string
有默认值的参数 stature: string='水桶腰'
对象类型参数:function add({one, two}:{one:number, two:number}) {}
返回值
void 返回值为空
never 永远执行不完
函数定义的方法
data:image/s3,"s3://crabby-images/df148/df148cf3d2ef141802a6dacc28eebf5c8481fe20" alt=""
4、接口、类型别名和引用类型
接口和类型别名功能相似,可根据自己喜好使用
接口参数可增加任意类型: [propname: string]: any;
类型别名: type Person = { name: string, age: number }
const pers: Person[] = [
{ name: 'adkl', age: 23 }, { name: 'adkl', age: 23 },
]
data:image/s3,"s3://crabby-images/47fa5/47fa50e2aae89fe27a10d7e7eebe9376e8788270" alt=""
引用类型: 数组,String, Data, RegExp
data:image/s3,"s3://crabby-images/988bf/988bf8341f180f1bf11a5bf69cbf1c426c8c4d1c" alt=""
5、类 — 关键字的使用和java一样
抽象类:abstract classGirl { abstract skill() }
因为没有具体的方法,所以我们这里不写括号,子类中必须做方法的实现
范围修饰符 private 只允许在类的内部被调用
范围修饰符 protected 只允许在类内及继承的子类中使用
范围修饰符 public(默认值) 在内部外部都可以访问
属性修饰符 readonly 只可读取,不可修改
data:image/s3,"s3://crabby-images/67b6e/67b6ecff759b9128e300afe904bac10ed63838f8" alt=""
类的继承使用关键字:extends
子类constructor方法中:必须调用super();
data:image/s3,"s3://crabby-images/b7d5b/b7d5bc8781efa6391585dacbebeb02028bee42dc" alt=""
6、命名空间
data:image/s3,"s3://crabby-images/b00fd/b00fd056d383bf627b025aea9c191f597422b193" alt=""
网友评论