【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插件,以本地静态服务器形式运行网页。

相关推荐
伍哥的传说26 分钟前
鸿蒙系统(HarmonyOS)应用开发之手势锁屏密码锁(PatternLock)
前端·华为·前端框架·harmonyos·鸿蒙
yugi98783828 分钟前
前端跨域问题解决Access to XMLHttpRequest at xxx from has been blocked by CORS policy
前端
浪裡遊39 分钟前
Sass详解:功能特性、常用方法与最佳实践
开发语言·前端·javascript·css·vue.js·rust·sass
旧曲重听11 小时前
最快实现的前端灰度方案
前端·程序人生·状态模式
默默coding的程序猿2 小时前
3.前端和后端参数不一致,后端接不到数据的解决方案
java·前端·spring·ssm·springboot·idea·springcloud
夏梦春蝉2 小时前
ES6从入门到精通:常用知识点
前端·javascript·es6
归于尽2 小时前
useEffect玩转React Hooks生命周期
前端·react.js
G等你下课2 小时前
React useEffect 详解与运用
前端·react.js
我想说一句2 小时前
当饼干遇上代码:一场HTTP与Cookie的奇幻漂流 🍪🌊
前端·javascript
funnycoffee1232 小时前
Huawei 6730 Switch software upgrade example版本升级
java·前端·华为