当前位置: 首页 > news >正文

ES6模块化详解:导入与导出方式

在现代 JavaScript 开发中,模块化是代码管理和组织的重要工具。ES6(ECMAScript 2015)引入了模块化的概念,通过 importexport 来组织代码,使得模块的管理变得更加清晰和简洁。本文将详细介绍 ES6 中的各种模块导入导出方式,包括 *导入、命名导入、默认导入、命名 + 默认导入、动态导入,分别导出、统一导出和默认导出。

1. 模块化基础

在 ES6 之前,JavaScript 没有原生的模块化机制。我们通常通过 require()module.exports(在 Node.js 中)来实现模块化。ES6 引入了模块化规范,使得在浏览器和 Node.js 中都能够使用统一的模块化机制。

1.1 export 和 import

  • export 用于将模块中的功能暴露出去。
  • import 用于从其他模块中导入功能。

1.2 模块化的优势

  • 代码重用:可以将功能拆分成多个文件,并在其他地方使用。
  • 更好的依赖管理:模块可以显式地声明其依赖,避免了全局变量污染。
  • 易于维护:模块化的代码更易于理解、调试和维护。

2. import 和 export 的基本用法

2.1 默认导出与命名导出

2.1.1 默认导出 (Default Export)

默认导出允许你导出一个模块的主要功能,其他模块可以直接导入这个功能,而不需要花括号。

示例:

math.js(模块文件):

// 默认导出
export default function add(a, b) {return a + b;
}

导入方式:

// 导入默认导出的函数
import add from './math';console.log(add(2, 3)); // 输出: 5
2.1.2 命名导出 (Named Export)

命名导出允许你导出一个模块中的多个功能,并且导入时需要使用相同的名称。

示例:

math.js(模块文件):

// 命名导出
export function add(a, b) {return a + b;
}export function subtract(a, b) {return a - b;
}

导入方式:

// 导入命名导出的函数
import { add, subtract } from './math';console.log(add(2, 3)); // 输出: 5
console.log(subtract(5, 3)); // 输出: 2

3. import 的多种方式

ES6 允许使用不同的方式来导入模块的功能。

3.1 * 导入

* 导入会将模块中所有的命名导出作为一个对象导入,可以通过该对象来访问所有导出的功能。

示例:

math.js(模块文件):

export function add(a, b) {return a + b;
}export function subtract(a, b) {return a - b;
}

导入方式:

import * as math from './math';console.log(math.add(2, 3)); // 输出: 5
console.log(math.subtract(5, 3)); // 输出: 2

3.2 命名导入

命名导入允许从模块中导入一个或多个具名功能。导入时需要使用花括号包围需要的功能。

示例:

math.js(模块文件):

export function add(a, b) {return a + b;
}export function subtract(a, b) {return a - b;
}

导入方式:

import { add } from './math';console.log(add(2, 3)); // 输出: 5

3.3 默认导入

默认导入用来导入模块的默认导出,它不需要使用花括号。

示例:

math.js(模块文件):

export default function add(a, b) {return a + b;
}

导入方式:

import add from './math';console.log(add(2, 3)); // 输出: 5

3.4 命名导入 + 默认导入

如果一个模块同时使用了默认导出和命名导出,可以结合使用默认导入和命名导入。

示例:

math.js(模块文件):

export default function add(a, b) {return a + b;
}export function subtract(a, b) {return a - b;
}

导入方式:

import add, { subtract } from './math';console.log(add(2, 3)); // 输出: 5
console.log(subtract(5, 3)); // 输出: 2

4. 导出的方式

4.1 统一导出

统一导出允许你将多个功能一起导出。这通常在模块的最后使用。

示例:

math.js(模块文件):

function add(a, b) {return a + b;
}function subtract(a, b) {return a - b;
}// 统一导出
export { add, subtract };

导入方式:

import { add, subtract } from './math';console.log(add(2, 3)); // 输出: 5
console.log(subtract(5, 3)); // 输出: 2

4.2 分别导出

分别导出允许你在多个位置导出模块的功能。

示例:

math.js(模块文件):

// 分别导出
export function add(a, b) {return a + b;
}export function subtract(a, b) {return a - b;
}

导入方式:

import { add, subtract } from './math';console.log(add(2, 3)); // 输出: 5
console.log(subtract(5, 3)); // 输出: 2

4.3 默认导出

默认导出是模块的主要导出,通常一个模块只会有一个默认导出。

示例:

math.js(模块文件):

export default function add(a, b) {return a + b;
}

导入方式:

import add from './math';console.log(add(2, 3)); // 输出: 5

5. 动态导入

动态导入允许按需加载模块。它返回一个 Promise,可以在需要时动态加载模块。这对于按需加载和代码拆分非常有用。

示例:

// 动态导入模块
import('./math').then(math => {console.log(math.add(2, 3)); // 输出: 5
});

动态导入常用于大型应用,尤其是在涉及到懒加载时。

6. 总结

  • 默认导出:每个模块只能有一个默认导出,适用于模块的主要功能。
  • 命名(分别)导出:模块可以有多个命名导出,适用于多个功能的导出。
  • * 导入:将模块中的所有命名导出作为对象导入。
  • 命名导入 + 默认导入:可以结合命名导入和默认导入,导入模块中的多个功能。
  • 动态导入:用于按需加载模块,返回一个 Promise
  • 分别导出与统一导出:分别导出每个功能或统一导出多个功能。

相关文章:

ES6模块化详解:导入与导出方式

在现代 JavaScript 开发中,模块化是代码管理和组织的重要工具。ES6(ECMAScript 2015)引入了模块化的概念,通过 import 和 export 来组织代码,使得模块的管理变得更加清晰和简洁。本文将详细介绍 ES6 中的各种模块导入导…...

每日学习Java之一万个为什么?[MySQL面试篇]

分析SQL语句执行流程中遇到的问题 前言1 MySQL是怎么在一台服务器上启动的2 MySQL主库和从库是同时启动保持Alive的吗?3 如果不是主从怎么在启动的时候保证数据一致性4 ACID原则在MySQL上的体现5 数据在MySQL是通过什么DTO实现的6 客户端怎么与MySQL Server建立连接…...

常用空间数据结构对比

空间数据结构是用来组织和查询多维空间数据的算法结构。它们在地理信息系统 (GIS)、计算机图形学、机器人导航、机器学习等领域非常重要。以下是几种常见空间数据结构的对比: 1. 四叉树(Quadtree) 适用场景:二维空间数据&#x…...

AnythingLLM+LM Studio本地知识库构建

前置操作: 已经安装以下软件,并配置后: DeepSeek-R1-Distill-Llama-8B-Q4_K_M.ggufLM-Studio-0.3.10-6-x64 软件准备: 下载AnythingLLM:AnythingLLM | The all-in-one AI application for everyone 点击"Dow…...

使用 Java 更新 Word 文档中的图表数据-超详细

使用 Java 更新 Word 文档中的图表数据 在日常的工作中,尤其是在数据分析和报告自动化的场景中,可能会遇到需要定期更新 Word 文档中的图表数据的需求。比如,生成数据报告时,我们需要在图表中更新一些动态的数据值。今天&#xf…...

Qt常用控件之下拉框QComboBox

下拉框QComboBox QComboBox 是一个下拉框控件。 1. QComboBox属性 属性说明currentText当前选中的文本。currentIndex当前选中的条目下标(从 0 开始,如果没有条目被选中则该值为 -1)。editable是否允许被修改。为 true 时,QCom…...

Qt 中集成mqtt协议

一,引入qmqtt 库 我是将整个头文件/源文件都添加到了工程中进行编译,这样 跨平台时 方便,直接编译就行了。 原始仓库路径:https://github.com/emqx/qmqtt/tree/master 二,使用 声明一个单例类,将订阅到…...

2024年第十五届蓝桥杯大赛软件赛省赛Python大学A组真题解析

文章目录 试题A: 拼正方形(本题总分:5 分)解析答案试题B: 召唤数学精灵(本题总分:5 分)解析答案试题C: 数字诗意解析答案试题A: 拼正方形(本题总分:5 分) 【问题描述】 小蓝正在玩拼图游戏,他有7385137888721 个2 2 的方块和10470245 个1 1 的方块,他需要从中挑出一些…...

AI大模型-提示工程学习笔记19-自我反思

目录 1. 自我反思的核心思想 (1) LLM 的局限性 (2) Reflexion 的解决方案 2. Reflexion 的工作流程 (1) 任务输入 (2) 初始生成 (3) 反思 (Reflection) (4) 调整与改进 (5) 迭代 (6) 结果输出 3. Reflexion 的关键组件 (1) 大语言模型 (LLM) (2) 反思者 (Reflector…...

GaussDB 学习实战指南:从部署到高并发优化的全流程解析

引言 GaussDB 作为华为推出的高性能分布式数据库,凭借其 分布式架构、高可用性、云原生支持 等特性,成为企业级应用的核心选择。本文将以 实战操作为核心,覆盖 集群部署、数据分片、性能调优、容灾备份、云上迁移 五大场景,通过真实案例与代码示例,助你快速掌握 GaussDB …...

vue3 Props的使用

Props是什么? 官方地址:Props | Vue.js 在 Vue 中,props 是父组件向子组件传递数据的一种机制。 props 是子组件中定义的自定义属性,父组件通过这些属性向子组件传递数据。 它们是单向数据流的一部分,意味着数据只能…...

Ecode前后端传值

说明 在泛微 E9 系统开发过程中,使用 Ecode 调用后端接口并进行传值是极为常见且关键的操作。在上一篇文章中,我们探讨了 Ecode 调用后端代码的相关内容,本文将深入剖析在 Ecode 中如何向后端传值,以及后端又该如何处理接收这些值…...

【Linux】进程状态(二)

目录 前言: 一、进程状态: 1.运行状态(时间片) 2.阻塞状态 3.阻塞挂起状态 二、Linux进程状态: 1.运行状态(R)和阻塞状态(S) 2.深度睡眠状态(D) 3.停止状态(T) 3.1使进程在后台运行 4.追踪暂停状态(t) 5.死亡状态(X)和僵尸状态…...

domain 网络安全 网络安全域

🍅 点击文末小卡片 ,免费获取网络安全全套资料,资料在手,涨薪更快 文章目录 1、域的概述 1.1、工作组与域1.2、域的特点1.3、域的组成1.4、域的部署概述1.5、活动目录1.6、组策略GPO 2、域的部署实验 2.1、建立局域网&#xf…...

链表和STL —— list 【复习笔记】

1. 链表 1.1 链表的定义和类型 和顺序表一样,链表也是一种线性表,线性表存储结构为链式存储就是链表 链式存储不仅要保存数据元素,还要保存数据元素间的关系,这两个部分信息形成了结点。结点有两个域:数据域&#x…...

Java Map实现类面试题

Java Map实现类面试题 HashMap Q1: HashMap的实现原理是什么? HashMap基于哈希表实现,使用数组链表红黑树(Java 8)的数据结构。 public class HashMapPrincipleExample {// 模拟HashMap的基本结构public class SimpleHashMap&…...

技术架构和工程架构区别

技术架构 技术架构‌是对某一技术问题解决方案的结构化描述,包括组件结构及其交互关系。它涵盖部署方案、存储方案、缓存方案、日志方案等多个方面,旨在通过组织人员和技术,以最低的成本满足需求和应对变化,保障软件的稳定高效运…...

简单介绍JVM

1.什么是JVM? JVM就是Java虚拟机【Java Virtual Machine】,简称JVM。主要部分包括类加载子系统,运行时数据区,执行引擎,本地方法库等,接下来我们一一介绍 2.类加载子系统 JVM中运行的就是我们日常写的JA…...

纷析云:赋能企业财务数字化转型的开源解决方案

在企业数字化转型的浪潮中,财务管理的高效与安全成为关键。纷析云凭借其开源、安全、灵活的财务软件解决方案,为企业提供了一条理想的转型路径。 一、开源的力量:自主、安全、高效 纷析云的核心优势在于其100%开源的财务软件源码。这意味着…...

DeepSeek开源周第二弹:DeepEP如何用RDMA+FP8让MoE模型飞起来?

一、引言:MoE模型的通信瓶颈与DeepEP的诞生 在混合专家(MoE)模型训练中,专家间的全对全(All-to-All)通信成为性能瓶颈。传统方案在跨节点传输时带宽利用率不足50%,延迟高达300μs以上。DeepSee…...

Claude in Excel:原生集成的AI表格协作者

1. 项目概述:这不是插件,是Excel里长出来的AI同事“Claude in Excel”这个标题刚看到时,我下意识点开几个技术社区翻了一圈,发现多数人第一反应是:“又一个AI插件?”——其实完全不是。它根本没走传统Offic…...

App无辜躺枪?手把手教你搞定腾讯手机管家误报导致的应用商店下架

当合规应用遭遇误报下架:开发者系统性应对指南运动健康类应用被标记为金融诈骗软件?社交工具因"病毒风险"被各大商店紧急下架?这类看似荒谬的误报事件,正在成为中小开发团队的"无妄之灾"。某知名运动App开发团…...

新手也能懂的SSRF漏洞实战:用iwebsec靶场复现文件读取与内网探测

从零开始掌握SSRF漏洞:iwebsec靶场实战指南1. 认识SSRF漏洞的本质想象一下,你正在一家高档餐厅点餐,服务员承诺可以帮你从任何地方获取食材——包括隔壁竞争对手的厨房。SSRF(Server-Side Request Forgery)漏洞就像这个…...

告别道路预测老套路:用ParkPredict+模型思路,解决停车场里的‘鬼探头’难题

破解泊车场景预测困局:ParkPredict模型的技术革新与实践停车场里的每一次转向、倒车和避让,都是对自动驾驶系统预测能力的极限挑战。与开放道路的规则明确不同,这里没有清晰的车道线指引,没有统一的行驶方向,只有随时可…...

BLE四大广播模式详解:可连接/不可连接/定向/周期广播

一、前言在低功耗蓝牙(BLE)开发中,广播(Advertising)是设备发现、连接建立、数据广播、设备重连的核心基石,所有BLE交互流程均始于广播报文的收发。不同于传统经典蓝牙,BLE所有广播行为标准化、…...

Python基础语法:生成器 generator(yield)

一、简介根据指定的规则循环生成数据,当条件不成立时则生成数据结束。数据不是一次性全部生成出来,而是使用一个,再生成一个,好处是可以节约大量的内存。就像设计模式中的懒汉式。适合处理大数据或流数。生成器是一种特殊的迭代器…...

解决Claude Code访问不稳定与Token不足的痛点

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 解决Claude Code访问不稳定与Token不足的痛点 许多开发者将Claude Code作为日常编程的得力助手,用于代码生成、问题调试…...

【紧急预警】Lindy衰减临界点已提前至第8.3个月!2024最新《营销自动化寿命健康度白皮书》限时开放前500份

更多请点击: https://kaifayun.com 第一章:Lindy衰减临界点的理论重构与实证突破 Lindy效应传统上描述“越老越长寿”的非线性生存规律,但其在现代软件系统、开源生态与协议层技术栈中的适用边界正遭遇结构性挑战。本文首次将Lindy模型从静…...

基于雷达与光敏传感器的低功耗智能窗防设备设计与实现

1. 项目概述:一个基于雷达与光敏的智能窗防设备几年前,我因为一次短暂的出差,家里空置了几天,回来后就一直琢磨着怎么给家里的窗户加点“动静”。市面上的智能安防摄像头固然好,但要么需要复杂的布线,要么云…...

ComfyUI-Manager完整指南:如何轻松管理你的AI工作流扩展库

ComfyUI-Manager完整指南:如何轻松管理你的AI工作流扩展库 【免费下载链接】ComfyUI-Manager ComfyUI-Manager is an extension designed to enhance the usability of ComfyUI. It offers management functions to install, remove, disable, and enable various c…...