TypeScript模块与命名空间的关系和使用方法
作者:剑九 六千里
在TypeScript中就像在EC5中一样,任何包含顶级import或export的文件都被认为是一个模块,下面这篇文章主要给大家介绍了关于如何在TypeScript使用模块与命名空间以及注意事项的相关资料,需要的朋友可以参考下
一、模块
1. 全局模块
在默认情况下,当你开始在一个新的 TypeScript 文件中写下代码时,它处于全局命名空间中
在全局变量空间是危险的,因为他会与文件内的代码命名冲突。我们推荐使用下文中将要提到的文件模块
示例:
// 由于此时默认为全局变量 // 因此会报错:无法重新声明块范围变量“name”。ts(2451) let name = '张三';
2. 文件模块
文件模块也被称为外部模块。如果在你的 TypeScript 文件的根级别位置含有 import 或者 export,那么它会在这个文件中创建一个本地的作用域
模块是 TS 中外部模块的简称,侧重于代码的复用
模块在自身的作用域里执行,而不是在全局作用域里
一个模块里的变量、函数、类等在外部是不可见的,除非将其导出
如果想要使用一个模块里导出的变量,则需要导入
示例:
// 此时a,b和默认导出的name可以在其他文件导入使用 // c由于未导出,因此在其他文件导入c时会报错 export const a = 1; export const b = 2; const c = 3; export default { name: 'Tom' } // 导入 // import { a, b } from './xxx.ts'
3. 模块规范
- AMD:不要使用它,它仅能在浏览器工作
- SystemJs:这是一个好的实验,已经被 ES 模块替代
- ES 模块:它并没有准备好,浏览器暂时还不支持
- 使用 module: commonjs 来替代这些模块,commonjs在node和浏览器中都支持
二、命名空间
在代码量较大的情况下,为了避免命名空间冲突,可以将相似的函数、类、接口防止在命名空间内
命名空间可以将代码包裹起来,只对外暴露需要在外部访问的对象,命名空间内通过 export 向外导出
命名空间是内部模块,主要用于组织代码,避免命名冲突
示例:
// 注意:此处可以在当前文件直接使用,也可以在其他文件导入使用 export namespace person { class Woman { }; // 此处加了export关键字才会被导出,否则则为私有 export class Man { eat() { return '吃饭' } } } export namespace animal { class Bird { }; // 此处加了export关键字才会被导出,否则则为私有 export class Tiger { eat() { return '吃肉' } } // 命名空间嵌套命名空间 export namespace monkeyArea { export class Monkey { eat() { return '吃水果' } } } } let p = new person.Man(); console.log(p.eat()); // 吃饭 let t = new animal.Tiger(); console.log(t.eat()); // 吃肉 let m = new animal.monkeyArea.Monkey(); console.log(m.eat()); // 吃水果
三、文件模块和命名空间的关系
文件模块可以重复,多个文件导出同样的命名是被允许的文件模块是独立的,互相之间不影响命名空间全局具有唯一性,导出的名称不能重复
补充:同一模块下命名空间一致会合并;不同模块下同名命名空间不会合并
到此这篇关于TypeScript模块与命名空间的关系和使用方法的文章就介绍到这了,更多相关TypeScript模块与命名空间内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!