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

尚融宝07-前端模块化

目录

一、模块化简介

1、背景

2、模块化解决的问题

3、模块化规范

二、ES6模块化规范

1、导出模块

3、测试

三、默认暴露模块

1、默认暴露

2、导入模块

3、测试

四、封装代码

1、创建app.js

2、引入入口文件

3、测试


一、模块化简介

1、背景

创建04-module-demo目录,创建 “no-module” 目录,创建a.js

var star = '王力宏'

创建b.js

var star = 5

创建demo.html

从这个例子可以看出,star的值的不确定性很大,a和b两个脚本文件中的同名变量互相干扰。

<!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>
  <script src="a.js"></script>
  <script src="b.js"></script>
  <script>
    console.log(star)
  </script>
</body>
</html>

 此时打开浏览器访问demo.html控制台输出5

把a.js移动到b.js的下方后,控制台输出王力宏 

    <script src="b.js"></script>
    <script src="a.js"></script>

2、模块化解决的问题

模块化主要解决javascript程序全局空间内被污染的问题

3、模块化规范

  • CommonJS模块化规范(基于ES6语法之前)
    • 例如:node.js中的 require 引入模块,exports 导出模块
  • ES6模块化规范(使用ES6语法)
    • export 导出模块
    • import 引入模块

二、ES6模块化规范

1、导出模块

创建"module"目录,创建m1.js
// export let star = '王力宏'

// export function sing() {
//     console.log('大城小爱')
// }

// 或者用以下的导出方式
let star = '王力宏';

function sing() {
    console.log('大城小爱')
}

export { star, sing }

创建m2.js

export let star = 5
2、导入模块
创建demo.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>
  <script type="module">
    import * as m1 from './m1.js'
    import * as m2 from './m2.js'

    console.log(m1)
    console.log(m2)

    console.log(m1.star)
    console.log(m2.star)
    
    //还可以这样导入:解构赋值的形式
    import {star, sing} from './m1.js'
    import {star as star2} from './m2.js' //使用as防止重名
    console.log(star)
    sing()
    console.log(star2)
    
  </script>
</body>
</html>

3、测试

运行html文件测试

 

三、默认暴露模块

1、默认暴露

创建m3.js

//可以导出任意类型,但同时只能有一个export default
// export default 'helen'
// export default 99

//大部分情况是导出对象
export default{
  username: 'helen',
  age: 20,
  coding(){
    console.log('hello world')
  } 
}

2、导入模块

在demo.html中导入模块

//导入m3
import m3 from './m3.js'
console.log(m3)

3、测试

运行html文件测试

 

四、封装代码

1、创建app.js

可以看做是程序的入口文件

import * as m1 from './m1.js'
import * as m2 from './m2.js'
import m3 from './m3.js'

console.log(m1)
console.log(m2)
console.log(m3)

2、引入入口文件

创建demo-app.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>
  
  <script src="app.js" type="module"></script>
</body>
</html>

3、测试

运行html文件测试

 


http://www.kler.cn/a/1576.html

相关文章:

  • 攻防世界 ics-07
  • Agent | Dify中的两种可选模式
  • spring boot 多数据源集成mysql、postgresql、phoenix、doris等
  • CANN 学习——基于香橙派 KunpengPro(1)
  • JavaEE初阶——计算机工作原理
  • HackMyVM-Again靶机的测试报告
  • 2023年网络安全最应该看的书籍,弯道超车,拒绝看烂书
  • 【C++编译】gcc、gdb、make、cmake
  • 论文阅读和分析:Mathematical formula recognition using graph grammar
  • 线程安全(重点)
  • 202304读书笔记|《不被定义的女孩》——做最真实最漂亮的自己,依心而行
  • 2023秋招前端面试必会的面试题
  • 多层多输入的CNN-LSTM时间序列回归预测(卷积神经网络-长短期记忆网络)——附代码
  • STM32开发(九)STM32F103 通信 —— I2C通信编程详解
  • springcloud3 nacos,sentinel,ribbon,openfegin等整合案例4[fallback+blockhandler完美整合]
  • 基于深度学习的农作物叶片病害检测系统(UI界面+YOLOv5+训练数据集)
  • 门面设计模式
  • C#等高级语言运行过程
  • CSDN周赛第37期题解(Python版)
  • 近期投简历、找日常实习的一些碎碎念(大二---测试岗)
  • uboot主目录下Makefile文件的分析,以及配置过程分析
  • 【动态规划】最长上升子序列(单调队列、贪心优化)
  • 指针进阶(上)
  • 《世界棒球》:黑人联盟
  • Linux安装EMQX(简洁版)
  • 【C语言】一篇让你彻底吃透(结构体与结构体位段)