登录
首页 >  文章 >  前端

ES6模块导出导入方法详解

时间:2026-01-18 15:27:33 104浏览 收藏

在文章实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《ES6模块如何导入导出?》,聊聊,希望可以帮助到正在努力赚钱的你。

ES6模块通过export/import实现静态依赖管理。支持命名导出、批量命名导出和默认导出;import需在顶层,路径为字符串字面量,支持重命名、默认导入及仅执行导入;模块单例缓存,路径相同则共享实例。

javascript模块如何导入导出_ES6模块系统怎样工作?

ES6模块系统用 exportimport 实现静态、明确的代码组织方式,不依赖全局变量或脚本加载顺序,本质是编译时确定依赖关系。

导出(export)有三种常见写法

可以导出变量、函数、类,甚至默认导出一个值:

  • 命名导出:每个导出项必须有名字,可导出多个,接收时需用同名解构
    export const PI = 3.14;
    export function add(a, b) { return a + b; }
  • 批量命名导出:用大括号集中导出已有声明
    const name = "Alice";
    function greet() { return `Hi, ${name}`; }
    export { name, greet };
  • 默认导出:每个模块最多一个,接收时不需大括号,名字可自定
    export default function() { return "default action"; }

导入(import)要匹配导出类型

导入语句必须在顶层(不能在 if 或函数内),且路径必须是字符串字面量:

  • 导入命名导出:用大括号,名字必须和导出一致(可用 as 重命名)
    import { PI, add } from "./math.js";
    import { add as sum } from "./math.js";
  • 导入默认导出:不用大括号,可任意起名
    import myFunc from "./utils.js";
  • 同时导入默认和命名:默认放前面,命名放大括号里
    import main, { helper, VERSION } from "./module.js";
  • 只执行模块不导入值(比如初始化逻辑):
    import "./polyfill.js";

模块路径和文件后缀要注意

浏览器和 Node.js 对模块解析规则略有不同:

  • 相对路径("./util")、绝对路径("/src/index")和完整 URL 都支持
  • Node.js 从 v14.13+ 默认支持 .js 后缀,但推荐显式写出("./util.js"),避免歧义
  • 浏览器中 script 标签需加 type="module",否则不识别 import/export

模块是单例且自动缓存

同一个模块路径无论被 import 多少次,只执行一次,所有导入者共享同一份导出对象 —— 这意味着修改导出的值(如导出一个对象),其他模块能立刻看到变化。

基本上就这些。ES6模块不是黑盒,它靠静态语法分析建立依赖图,构建工具和运行时都据此处理加载与执行顺序。

终于介绍完啦!小伙伴们,这篇关于《ES6模块导出导入方法详解》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>