说说对TypeScript中命名空间与模块的理解?区别?

一、模块

TypeScript与ECMAScript2015一样,任何包含顶级import或者export的文件都被当成一个模块相反地,如果一个文件不带有顶级的import或者export声明,那么它的内容被视为全局可见的

例如我们在在一个TypeScript工程下建立一个文件1.ts,声明一个变量,如下:

然后在另一个文件同样声明一个变量,这时候会出现错误信息

提示重复声明a变量,但是所处的空间是全局的

如果需要解决这个问题,则通过import或者export引l入模块系统即可,如下:

在typescript中,export关键字可以导出变量或者类型,用法与es6模块一致,如下:

通过import引入模块,如下:

 

二、命名空间

命名空间一个最明确的目的就是解决重名问题

命名空间定义了标识符的可见范围,一个标识符可在多个名字空间中定义,它在不同名字空间中的含义是互不相干

这样,在一个新的名字空间中可定义任何标识符,它们不会与任何已有的标识符发生冲突,因为已有的定义都处于

其他名字空间中

TypeScript中命名空间使用namespace来定义,语法格式如下:

以上定义了一个命名空间SomeNameSpaceName,如果我们需要在外部可以调用SomeNameSpaceName中的类和接口,则需要在类和接口添加export关键字

使用方式如下:

命名空间本质上是一个对象,作用是将一系列相关的全局变量组织到一个对象的属性,如下:

编译成js如下:

 

三、区别

·命名空间是位于全局命名空间下的一个普通的带有名字的JavaScript对象,使用起来十分容易。但就像其它的

全局命名空间污染一样,它很难去识别组件之间的依赖关系,尤其是在大型的应用中

·像命名空间一样,模块可以包含代码和声明。不同的是模块可以声明它的依赖

在正常的TS项目开发过程中并不建议用命名空间,但通常在通过d.ts文件标记js库类型的时候使用命名空间,

主要作用是给编译器编写代码的时候参考使用

 

 
posted @ 2025-04-03 09:49  蓦然JL  阅读(29)  评论(0)    收藏  举报
访问主页
关注我
关注微博
私信我
返回顶部