• 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()); // 吃水果
    

    三、文件模块和命名空间的关系

    • 文件模块可以重复,多个文件导出同样的命名是被允许的
    • 文件模块是独立的,互相之间不影响
    • 命名空间全局具有唯一性,导出的名称不能重复

    补充:同一模块下命名空间一致会合并;不同模块下同名命名空间不会合并


    总结

    本文主要记录了ts中的模块与命名空间,以供参考。下次再见

  • 相关阅读:
    2022年数维杯国际赛A题 自动地震水平跟踪
    数组的拷贝和反转和扩容与缩减
    【WebRTC】QoS 拥塞控制 GCC 理论 Sender Side BWE 或 REMB
    颜色分类(中等)
    基于邻接矩阵的深度优先算法和广度优先算法
    2023.11.15 hive函数分类标准
    列表、字典、元组、集合总结
    【Spring】bean的基础配置
    分布式任务调度平台——XXL-JOB
    netty系列之:Bootstrap,ServerBootstrap和netty中的实现
  • 原文地址:https://blog.csdn.net/to_the_Future/article/details/127044557