类型兼容
TypeScript里的类型兼容性是基于结构类型系统的,只要二者的结构组成相同,就认为二者属于统一类型
1 | interface Pet { |
TypeScript里的类型兼容性是基于结构类型系统的,只要二者的结构组成相同,就认为二者属于统一类型
1 | interface Pet { |
三斜线指令是包含单个XML标签的单行注释。 注释的内容会做为编译器指令使用
仅可放在包含它的文件的最顶端。一个三斜线指令前面只能出现单行或多行注释,包括其他的三斜线指令。否则被当为普通注释
/// <reference path="..." />
用于声明文件间的依赖
当使用–out或–outFile时,它也可以做为调整输出内容顺序的一种方法。 文件在输出文件内容中的位置与经过预处理后的输入顺序一致
编译器通过预处理解析所有三斜线指令,将额外的文件加到编译过程中。
过程从一些根文件开始,它们在命令行中指定的文件或是tsconfig.json
中的files
列表里的文件。这些根文件按指定的顺序预处理。在一个文件被加入列表前,它包含的所有三斜线引用都要被处理,还有它们包含的目标。 三斜线引用以它们在文件里出现的顺序,使用深度优先的方式解析
一个三斜线引用路径是相对于包含它的文件的,如果不是根文件
引用不存在的文件会报错。 一个文件用三斜线指令引用自己会报错。
三斜线引用会被忽略;它们不会增加新文件,也不会改变给定文件的顺序
/// <reference types="..." />
指令声明了对某个包的依赖。
对这些包的名字的解析与在import语句里对模块名的解析类似。 可以简单地把三斜线类型引用指令当做import声明的包
仅当在你需要写一个d.ts文件时才使用这个指令。
当且仅当 结果文件中使用了引用的包里的声明时才会在生成的声明文件里添加/// <reference types="..." />
语句
若要在.ts文件里声明一个对@types包的依赖,使用–types命令行选项或在tsconfig.json里指定
/// <reference no-default-lib="true"/>
把一个文件标记成 默认库。在lib.d.ts
文件和它不同的变体的顶端看到这个注释
这个指令告诉编译器在编译过程中 不要 包含这个默认库(比如,lib.d.ts
)。 这与在命令行上使用--noLib
相似
当传递了--skipDefaultLibChec
k时,编译器只会忽略检查带有/// <reference no-default-lib="true"/>
的文件
/// <amd-module />
指令允许给编译器传入一个可选的模块名
1 | ///<amd-module name='NamedModule'/> |
这会将NamedModule
传入到AMD define
函数里
可以在类型层面上描述JavaScript对象的模型
声明合并指指编译器将针对同一个名字的两个独立声明合并为单一声明。 合并后的声明同时拥有原先两个声明的特性。 任何数量的声明都可被合并;不局限于两个声明
一个类型需要基于另外一个类型,但是你又不想拷贝一份,这个时候可以考虑使用映射类型
映射类型建立在索引签名的语法上
1 | type OptionsFlags<Type> = { |
用来帮助我们描述输入类型和输出类型之间的关系
1 | interface Animal { |
一般多搭配泛型使用