引入TS的背景:JS的类型系统存在“先天缺陷”,JS代码中绝大部分错误都是类型错误。
TypeScript:静态类型(编译期做类型检查)编程语言,先编译后执行
javaScript:动态类型(执行期做类型检查)编程语言
TS优势:1.更早发现错误;提升效率2.代码中的任何位置都有代码提示,增强体验感
3.强大的类型系统提升了代码的可维护性,重构代码更容易;4.支持最新的ECMAScript语法
5.TS类型推断机制。
node安装TS:npm i -g typescript (全局安装)
验证是否安装成功:tsc -v 报错
1.npm install -g ts-node
2. get-ExecutionPolicy
3. Set-ExecutionPolicy -Scope CurrentUser
编译并运行TS代码:1.创建hello.ts文件(TS文件后缀名为.ts)
2.将ts文件编译为JS:在终端输入tsc hello.ts(此时在同级目录中会出现一个js文件)
3.执行js文件:node hello.js
注:由TS编译生成的JS文件,代码中就没有类型信息了。
简化运行TS步骤:使用ts-node包,直接在Node.js中执行TS代码
使用npm i -g ts-node安装
ts-node hello.ts
解释:ts-node命令在内部偷偷将TS->JS ,然后子啊运行JS代码(不生成JS文件)
TypeScript是JS的超集,TS提供了JS的所有功能,并额外增加了类型系统。
TS类型系统的主要优势:可以显示标记出代码中的意外行为,从而降低了发生错误的可能性
类型注解:let age:number=18 代码中的number就是类型注解
约定了什么类型就只能给改变量赋值该类型的值,否则就会报错。
any类型:可对该值进行任意操作,并且不会有代码提示,不提倡使用
typeof:可以在类型上下文中引用变量或属性的类型(类型查询),获取变量类型
typescript高级类型:
class类:
class Person{} 构造函数constructor无返回值,方法的类型注解(参数返回值)与对象方法相同;
继承:extends(继承父类) implements(实现接口interface)
类成员可见性 public protected(仅对其声明所在的类与子类中可见,实例对象中无法访问) private(仅在当前类中使用)
readonly:表示只读,可在构造函数中赋值,用来防止在构造函数之外对属性进行赋值,只能修饰属性不能修饰方法,接口或{}表示的对象类型也可以用其修饰
类型兼容性:
标明类型系统
结构化类型系统(TS所采用,也叫鸭子类型):如果两个对象具有相同的形状,则认为它们属于同一类型
class point{
x:number
y:number
}
class point2D{
x:number
y:number
}
const p2:point=new point2D()
/point与point2D是两个不同名的类
变量p2的类型被显著标为point类型,但是它的值确实point2D的实例,并且没有类型错误
因为TS是结构化类型系统,只检查point和point2D的结构是否相同
但是,如果在标明类型系统中(C#,java等)中,它们是不同的类,类型无法兼容/
对于对象类型来说,成员多的可以赋值给成员少的,接口与类之间也可兼容
函数间的兼容性:参数少的可以赋值给参数多的
交叉类型:功能类似于接口继承,用于组合多个类型为一个类型
对比:对于同名属性时,交叉类型:兼容(函数重载)
接口继承:不兼容
泛型和keyof: 泛型的类型变量可以有多个,并且类型变量之间还可以约束
泛型接口:使用时必须显式指定具体的类型
JS中的数组在TS中就是一个泛型接口
泛型工具类型:Partical用来构造一个类型,将Type的所有属性设置为可选
Readonly Type的所有属性设置为只读
Pick<Type,Keys>
Record<Keys,Type>:属性键为Keys,属性类型为Type
表示新创建的对象有哪些属性,属性的类型
索引签名类型:当无法确定对象中有哪些属性时,使用索引签名类型
映射类型:基于就类型创建新类型,减少重复、提升开发效率 只能在类型别名中使用,不能再接口中使用
Typescript类型声明文件:用来为已存在的JS库提供类型信息
TS中两种文件类型:
.ts文件(代码实现文件) :既包含类型信息又包含可执行代码;
可以被编译为JS文件,然后执行代码
用途:编写程序代码的地方
.d.ts文件(类型声明文件):只包含类型信息;
不会生成js文件,仅用于提供类型信息
用途:为JS提供类型信息
类型声明文件使用:
内置类型声明文件:标准化内置API
第三方库的类型声明文件 :由DefinitelyTyped提供(github)
创建自己的类型声明文件步骤:
1.创建.d.ts类型声明文件
2.创建需共享的类型,并使用export导出
3.在需要使用的共享类型的.ts文件中,通过import导入即可(导入时.d.ts后缀可省略)
今天的文章【TypeScript基础知识概述[通俗易懂]分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/87792.html