文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-03-09 17:43

关注

一、模块

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. 模块规范

二、命名空间

在代码量较大的情况下,为了避免命名空间冲突,可以将相似的函数、类、接口防止在命名空间内

命名空间可以将代码包裹起来,只对外暴露需要在外部访问的对象,命名空间内通过 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模块与命名空间内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯