TypeScript命名空间合并讲解
前言:
回顾上一节的内容,在上一节中我们介绍了TS中最常见的声明合并:接口合并
我们从中了解了声明合并其实指的就是编译器会针对同名的声明合并为一个声明,合并的结果是合并后的声明会同时拥有原先两个或多个声明的特性
而接口合并的合并需要里面的成员是否有函数成员。对于里头的函数成员来说,每个同名函数声明都会被当成这个函数的一个重载,当接口 A与后来的接口 A合并时,后面的接口具有更高的优先级
今天要讲的内容也是TS中的声明合并,但这次是命名空间相关的合并
主要分两方面来讲,一是同名的命名空间之间的合并,二是命名空间和其他类型的合并。下面会一一讲述
同名的命名空间之间的合并
与接口合并相类似,两个或多个同名的命名空间也会合并其成员
那具体怎么合并呢?
对于同名的命名空间之间的合并,记住一下4点:
- 里头模块导出的同名接口会合并为一个接口
- 对于非导出成员,仅在其原有的(合并前的)命名空间内可见。也就是说合并之后,从其它命名空间合并进来的成员无法访问非导出成员
- 对于里头值的合并,如果里头值的名字相同,那么后来的命名空间的值会优先级会更高
- 对于没有冲突的成员,会直接混入
例如:
namespace Animals {
export class Cat { }
}
namespace Animals {
export interface Legged { numberOfLegs: number; }
export class Dog { }
}
等同于:
namespace Animals {
export interface Legged { numberOfLegs: number; }
export class Cat { }
export class Dog { }
}
上述例子中,两个同名的命名空间Animals,最终合并为一个命名空间,而且结果是三个没有冲突的东西,直接混合在一起了
命名空间和其他类型的合并
命名空间可以与其它类型的声明进行合并,比如与类和函数,比如和枚举类型
合并同名的命名空间和类
例如:
class Album {
label: Album.AlbumLabel;
}
namespace Album {
export class AlbumLabel { }//导出 `AlbumLabel`类,好让合并的类能访问
}
命名空间和类的合并,结果是一个类并带有一个内部类
合并同名的命名空间和函数
除了上述的内部类的模式,你在JavaScript里,创建一个函数稍后扩展它增加一些属性也是很常见的。 TypeScript使用声明合并来达到这个目的并保证类型安全
例如官方的一个例子:
function buildLabel(name: string): string {
return buildLabel.prefix + name + buildLabel.suffix;
}
namespace buildLabel {
export let suffix = "";
export let prefix = "Hello, ";
}
console.log(buildLabel("Sam Smith"));
同名的命名空间和枚举
可以用来扩展枚举,还是看官方给的例子吧
enum Color {
red = 1,
green = 2,
blue = 4
}
namespace Color {
export function mixColor(colorName: string) {
if (colorName == "yellow") {
return Color.red + Color.green;
}
else if (colorName == "white") {
return Color.red + Color.green + Color.blue;
}
else if (colorName == "magenta") {
return Color.red + Color.blue;
}
else if (colorName == "cyan") {
return Color.green + Color.blue;
}
}
}
注意:
并不是所有东西都能合并,需要注意:类不能与其它类或变量合并
到此这篇关于TS命名空间合并讲解的文章就介绍到这了,更多相关TS命名空间合并内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
JavaScript中offsetWidth的bug及解决方法
这篇文章主要为大家详细介绍了JavaScript中offsetWidth的bug及解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-05-05
getElementByIdx_x js自定义getElementById函数
最近看JS代码,发现不少人问getElementByIdx_x是什么函数,其实就是个getElementById自定义函数2012-01-01
JS 中的URLSearchParams 对象操作(以对象的形式上传参数到url)
这篇文章主要介绍了JS中URLSearchParams的基本用法,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-12-12
js实现的真正的iframe高度自适应(兼容IE,FF,Opera)
由于项目上的需要,要用一个iframe高度自适应的功能,在google上搜了很久,找了一些修改了下。大家可以测试下。2010-03-03


最新评论