【ES6】模块化

概述

模块功能主要有两个命令,exportimport

一个js文件就是一个模块。

参考视频

【一小时速通JavaScript模块化,涵盖CommonJS与ES6模块化-哔哩哔哩】 https://b23.tv/gZ1uK7V

导出成员

在正常变量、函数前加export关键字。

导入模块

在另一个模块中导入

万能导入
javascript 复制代码
import * as xxx from "xxx.js"

在HTML页面导入

html 复制代码
<script type="module" src="">

模块化的优点

防止命名冲突,每个模块都有自己的命名空间

  • 代码复用,每个模块可以被其他多个模块引用
  • 高维护性,修改一个模块其他引用该模块的地方都改变
  • 确保引入顺序的正确性,使用模块化之后一般都是在自己的中引入所依赖的模块,所以避免了依赖顺序的引入问题
html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script src="Point.js"></script>
</head>
<body>
    
</body>
    <script src="run.js"></script>
</html>

引入Point.js,再在run.js中创建实例和执行其他代码。

而通过模块化,可以直接在run.js中导入和使用Point.js中定义的类。

javascript 复制代码
import {Point,ColorPoint} from "./Point.js";

let cp = new ColorPoint(100,100,"red");

console.log(cp);

HTML代码也就可以简化:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    
</body>
    <script type="module" src="run.js"></script>
</html>

需要注意的是,模块功能貌似需要服务器,可以使用Live Server插件,以本地静态服务器形式运行网页。

相关推荐
代码搬运媛7 小时前
Jest 测试框架详解与实现指南
前端
counterxing8 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq8 小时前
windows下nginx的安装
linux·服务器·前端
之歆8 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜8 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai108088 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
kyriewen10 小时前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm11 小时前
元框架的工作原理详解
前端·前端框架
canonical_entropy11 小时前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程
zhangxingchao11 小时前
多 Agent 架构到底怎么选?从 Claude Agent Teams、Cognition/Devin 到工程落地原则
前端·人工智能·后端