前言:
回顾上一节的内容,在上一节中我们介绍了ts中最常见的声明合并:接口合并
我们从中了解了声明合并其实指的就是编译器会针对同名的声明合并为一个声明,合并的结果是合并后的声明会同时拥有原先两个或多个声明的特性
而接口合并的合并需要里面的成员是否有函数成员。对于里头的函数成员来说,每个同名函数声明都会被当成这个函数的一个重载,当接口 a与后来的接口 a合并时,后面的接口具有更高的优先级
今天要讲的内容也是ts中的声明合并,但这次是命名空间相关的合并
主要分两方面来讲,一是同名的命名空间之间的合并,二是命名空间和其他类型的合并。下面会一一讲述
与接口合并相类似,两个或多个同名的命名空间也会合并其成员
那具体怎么合并呢?
对于同名的命名空间之间的合并,记住一下4点:
里头模块导出的同名接口会合并为一个接口对于非导出成员,仅在其原有的(合并前的)命名空间内可见。也就是说合并之后,从其它命名空间合并进来的成员无法访问非导出成员对于里头值的合并,如果里头值的名字相同,那么后来的命名空间的值会优先级会更高对于没有冲突的成员,会直接之后用英语怎么说混入例如:
namespace animal别有幽愁暗恨生s { 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.albuml负利率时代abel;}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 =2022年元旦精美图片= "yellow") { return color.red + color.green; } el if (colorname == "white") { return color.red + color.green + color.blue; } el if (colorname == "magenta") { return color.red + color.blue; } el if (colorname == "cyan") { return color.green + color.blue; } }}
注意:
并不是所有东西都能合并,需要注意:类不能与其它类或变量合并
到此这篇关于ts命名空间合并讲解的文章就介绍到这了,更多相关ts命名空间合并内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!
本文发布于:2023-04-04 11:59:32,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/68dbf6165cf93f04ba878e03bef92e90.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:TypeScript命名空间合并讲解.doc
本文 PDF 下载地址:TypeScript命名空间合并讲解.pdf
留言与评论(共有 0 条评论) |