TypeScript 命名空间与模块

在 TypeScript 中,命名空间和模块是两种不同的代码组织方式,它们都旨在帮助你管理和维护大型代码库。命名空间提供了一种将相关功能组织在一起的方式,而模块则允许你将代码分解成可重用的单元。在本文中,我们将探讨命名空间和模块的概念,以及如何在 TypeScript 中使用导入和导出来管理代码。

命名空间(Namespaces)

命名空间是将相关函数、类、枚举、变量等组织在一起的一种方式。在 TypeScript 中,你可以使用 namespace 关键字来定义命名空间。

基本语法

namespace MathTool {export function add(num1: number, num2: number): number {return num1 + num2;}export function sub(num1: number, num2: number): number {return num1 - num2;}var PI = 3.14;export function circleArea(radius: number): number {return PI * radius * radius;}
}

在这个例子中,我们定义了一个名为 MathTool 的命名空间,并在其中导出了三个函数。

使用命名空间

console.log(MathTool.add(1, 2)); // 输出 3
console.log(MathTool.sub(1, 2)); // 输出 -1
const circleArea = MathTool.circleArea;
console.log(circleArea(1)); // 输出 3.14

模块(Modules)

模块是 TypeScript 中的另一种代码组织方式。通过使用 exportimport 关键字,你可以将函数、类、枚举、变量等导出到其他文件中使用。

单个导出与导入

你可以将一个实体导出为模块的一部分,然后在另一个文件中导入它。

// myModule.ts
export function myModuleLog() {console.log("myModuleLog");
}
// app.ts
import { myModuleLog } from './myModule';
myModuleLog(); // 输出 "myModuleLog"

多个导出与导入

你可以从单个文件中导出多个实体,然后在另一个文件中导入它们。

// mathTool.ts
export function add(num1: number, num2: number): number {return num1 + num2;
}
export function sub(num1: number, num2: number): number {return num1 - num2;
}
// app.ts
import { add, sub } from './mathTool';
console.log(add(1, 2)); // 输出 3
console.log(sub(1, 2)); // 输出 -1

单个导入

你可以将整个模块导入,而不是单独的实体。

// app.ts
import * as MathTool from './mathTool';
console.log(MathTool.add(1, 2)); // 输出 3
console.log(MathTool.sub(1, 2)); // 输出 -1

多个导入

你可以从一个模块中导入多个实体。

// app.ts
import { add, sub, circleArea as area } from './mathTool';
console.log(add(1, 2)); // 输出 3
console.log(sub(1, 2)); // 输出 -1
console.log(area(1)); // 输出 3.14

重命名导入

在导入时,你可以为导入的实体指定一个新的名字。

// app.ts
import { add as sum, sub as difference } from './mathTool';
console.log(sum(1, 2)); // 输出 3
console.log(difference(1, 2)); // 输出 -1

结论

命名空间和模块是 TypeScript 中强大的代码组织工具。命名空间允许你将相关的代码组织在一起,而模块则提供了一种将代码分解成可重用单元的方式。通过使用 exportimport,你可以轻松地在不同的文件和模块之间共享代码。这些特性使得 TypeScript 成为一个非常适合大型项目的语言。

希望这篇文章能帮助你更好地理解和使用 TypeScript 的命名空间和模块。如果你有任何问题或想要进一步探讨,欢迎在评论区留下你的想法!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/887874.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vue 原理详解

Vue 原理详解 Vue.js 是一个渐进式框架,它通过数据驱动视图更新和响应式编程使得前端开发变得更加简单高效。在 Vue 的内部实现中,编译过程和响应式机制是两个至关重要的组成部分。本文将详细介绍 Vue.js 的编译器、响应式系统和运行时的工作原理&#…

PS的功能学习

背景差色较大,就魔棒 魔棒的连续就是倒水点的跨越问题 魔棒的容差的选择就有点看经验了,看颜色的统一程度选择 Ctrl D 取消当前所有的选区 至于快速选择工具,和对象选择工具也差不多,只不过控制范围变成了一块一块的&#x…

深度学习实验--初步探索数据增强、优化器对模型的影响

🍨 本文为🔗365天深度学习训练营 中的学习记录博客🍖 原作者:K同学啊 前言 这次主要是探究,优化器、数据增强对模型训练的影响;基础篇还剩下几个, 后面的难度会逐步提升;越学,越觉得这个东西很…

新型大语言模型的预训练与后训练范式,谷歌的Gemma 2语言模型

前言:大型语言模型(LLMs)的发展历程可以说是非常长,从早期的GPT模型一路走到了今天这些复杂的、公开权重的大型语言模型。最初,LLM的训练过程只关注预训练,但后来逐步扩展到了包括预训练和后训练在内的完整…

Linux:systemd进程管理【1】

整体理解 要快速掌握Linux的systemd并覆盖80%的使用场景,以下是最重要的20%知识点: Systemd简介与核心功能: Systemd是一个系统和服务管理器,作为Linux系统的PID 1进程,负责启动和管理其他系统组件。它提供并行启动服…

SQL Server管理员sa登录失败原因

文章目录 一、开启混合登录模式二、启用sa三、更改密码四、登录sa一、开启混合登录模式 用Windows身份登录数据库服务。 在连接名上右键→属性。 在安全性选项卡下,选择【SQL Server和Windows身份验证模式】,点击【确定】,提示需要重启服务。 Win+R,输入指令:services.ms…

logminer挖掘日志归档查找问题

--根据发生问题时间点查找归档文件 select first_time,NAME from gv$archived_log where first_time>2016-03-15 17:00:00 and first_time<2016-03-15 21:00:00; 2016-03-15 17:23:55 ARCH/jxdb/archivelog/2016_03_15/thread_1_seq_41588.4060.906577337 2016-03-15 17:…

如何监控Elasticsearch集群状态?

大家好&#xff0c;我是锋哥。今天分享关于【如何监控Elasticsearch集群状态&#xff1f;】面试题。希望对大家有帮助&#xff1b; 如何监控Elasticsearch集群状态&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 监控 Elasticsearch 集群的状态对于确保…

C# 集合(Collection)

文章目录 前言一、动态数组&#xff08;ArrayList&#xff09;二、哈希表&#xff08;Hashtable&#xff09;三、排序列表&#xff08;SortedList&#xff09;四、堆栈&#xff08;Stack&#xff09;五、队列&#xff08;Queue&#xff09;六、点阵列&#xff08;BitArray&…

TypeScript 迭代器与装饰器

TypeScript 作为 JavaScript 的一个超集&#xff0c;提供了许多高级特性来增强代码的可读性、可维护性和类型安全性。在本文中&#xff0c;我们将探讨两个这样的特性&#xff1a;迭代器和装饰器。迭代器允许我们以一致的方式遍历数据集合&#xff0c;而装饰器则提供了一种特殊的…

浏览器的数据六种存储方法比较 :LocalStorage vs. IndexedDB vs. Cookies vs. OPFS vs. WASM-SQLite

在构建该 Web 应用程序&#xff0c;并且希望将数据存储在用户浏览器中。也许您只需要存储一些小标志&#xff0c;或者甚至需要一个成熟的数据库。 我们构建的 Web 应用程序类型发生了显着变化。在网络发展的早期&#xff0c;我们提供静态 html 文件。然后我们提供动态渲染的 h…

flutter in_app_purchase google支付 PG-GEMF-01错误

问题&#xff1a;PG-GEMF-01错误 flutter 使用in_app_purchase插件升降级订阅时报错PG-GEMF-01。 解决方案&#xff1a; 升降级订阅时&#xff0c;确保不调用 MethodCallHandlerImpl.java文件中的 setObfuscatedAccountId()方法、setObfuscatedProfileId()方法 原因&#xf…

Docker 容器隔离关键技术:Capabilities

Docker 容器隔离关键技术&#xff1a;Capabilities 在 Docker 中&#xff0c;Capabilities 是一种权限管理技术&#xff0c;它将 Linux 系统中传统的超级用户&#xff08;root&#xff09;权限拆分为多个独立的小权限&#xff08;目前为 38 项&#xff09;。这使得我们可以为容…

蓝桥杯备赛笔记(一)

这里的笔记是关于蓝桥杯关键知识点的记录&#xff0c;有别于基础语法&#xff0c;很多内容只要求会用就行&#xff0c;无需深入掌握。 文章目录 前言一、编程基础1.1 C基础格式和版本选择1.2 输入输出cin和cout&#xff1a; 1.3 string以下是字符串的一些简介&#xff1a;字符串…

【Redis】Redis介绍

目录 1.Redis是什么? 2. Redis特性 2.1 速度快 2.2 基于键值对的数据结构服务器 2.3 丰富的功能 2.4 简单稳定 2.5 客户端语言多 2.6 持久化 2.7 主从复制 2.8 高可用和分布式 3. Redis使用场景 3.1 缓存(Cache) 3.2 排行榜系统 3.3 计数器应用 3.4 社交网络 …

Redis使用场景-缓存-缓存穿透

前言 之前在针对实习面试的博文中讲到Redis在实际开发中的生产问题&#xff0c;其中缓存穿透、击穿、雪崩在面试中问的最频繁&#xff0c;本文加了图解&#xff0c;希望帮助你更直观的了解缓存穿透&#x1f600; &#xff08;放出之前写的针对实习面试的关于Redis生产问题的博…

STM32 ADC --- 多通道序列采样

STM32 ADC — 序列通道采样 文章目录 STM32 ADC --- 序列通道采样CubeMX配置代码编写总结 CubeMX配置 使用cubeMX生成HAL工程 扫描模式在配置多个通道时会自动变为Enable&#xff0c;这里需要注意的是需要将连续转换模式配置为Disable&#xff0c;将结束转换选择选择为每个通道…

树莓派2安装jupyterlab以便更好的编程体验

树莓派2 是一款很老的开发板了&#xff0c;但是它还能继续战斗。为了更好的编程体验&#xff0c;准备安装jupyterlab 安装jupyterlab 使用命令&#xff1a; pip install jupyterlab 该过程非常漫长&#xff0c;因为树莓派2是很老的板子&#xff0c;它需要安装一些arm7版本的…

C语言数据结构——详细讲解《队列》

C语言数据结构——详细讲解《队列》 前言一、队列的概念二、队列的操作&#xff08;一&#xff09;定义队列结构&#xff08;二&#xff09;初始化队列&#xff08;三&#xff09;入队列操作&#xff08;四&#xff09;出队列操作&#xff08;五&#xff09;获取队头元素&#…

【游资悟道】-作手新一悟道心法

作手新一经典语录节选&#xff1a; 乔帮主传完整版&#xff1a;做股票5年&#xff0c;炼成18式&#xff0c;成为A股低吸大神&#xff01;从小白到大神&#xff0c;散户炒股的六个过程&#xff0c;不看不知道自己水平 围着主线做&#xff0c;多研究龙头&#xff0c;研究涨停&am…