TypeScript模块与命名空间的关系和使用方法

 更新时间:2023年03月09日 10:20:26   作者:剑九 六千里  
在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模块与命名空间内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 计算新浪Weibo消息长度(还可以输入119字)

    计算新浪Weibo消息长度(还可以输入119字)

    此文为计算新浪Weibo的消息长度的方法. 就是在发言的时候还可以输入多少字,具体的实现如下,感兴趣的朋友可以参考下哈,希望对大家有所帮助
    2013-07-07
  • js实现开关灯效果

    js实现开关灯效果

    这篇文章主要为大家详细介绍了js实现开关灯效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • js实现控制文件拖拽并获取拖拽内容功能

    js实现控制文件拖拽并获取拖拽内容功能

    本片文章主要给大家分享了用JS写出控制文件拖拽并获取拖拽内容功能实现过程,以及代码分享,有兴趣的一起学习下。
    2018-02-02
  • TypeScript中交叉类型和联合类型的区别详解

    TypeScript中交叉类型和联合类型的区别详解

    联合类型(Union Types)和交叉类型(Intersection Types)是 TypeScript 中的两种高级类型,它们都用于组合多个类型并生成新的类型,但它们两者之间的用法不一样,本文小编就给大家讲讲TypeScript中交叉类型和联合类型的区别,需要的朋友可以参考下
    2023-09-09
  • SWFUpload多文件上传及文件个数限制的方法

    SWFUpload多文件上传及文件个数限制的方法

    这篇文章主要介绍了SWFUpload多文件上传及文件个数限制的方法,较为详细的分析了SWFUpload组件实现多文件上传的原理、使用方法与相关注意事项,需要的朋友可以参考下
    2016-05-05
  • 前端JavaScript实现文件压缩的全面优化指南

    前端JavaScript实现文件压缩的全面优化指南

    JavaScript文件大小直接影响网页加载速度和用户体验,本文将详细介绍从基础到高级的各种JavaScript压缩优化技术,小伙伴可以根据需求进行选择
    2025-04-04
  • js禁止表单重复提交

    js禁止表单重复提交

    这篇文章主要介绍了js禁止表单重复提交的方法,避免重复记录带来的问题,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • JavaScript实现循环轮播图

    JavaScript实现循环轮播图

    这篇文章主要为大家详细介绍了JavaScript实现循环轮播图,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • Javascript柯里化实现原理及作用解析

    Javascript柯里化实现原理及作用解析

    这篇文章主要介绍了Javascript柯里化实现原理及作用解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • 在JavaScript中查找字符串中最长单词的三种方法(推荐)

    在JavaScript中查找字符串中最长单词的三种方法(推荐)

    这篇文章主要介绍了在JavaScript中查找字符串中最长单词的三种方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01

最新评论