尚融宝07-前端模块化
迪丽瓦拉
2025-05-30 12:23:03
0

目录

一、模块化简介

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两个脚本文件中的同名变量互相干扰。



Document



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

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

    

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


Document



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



Document



3、测试

运行html文件测试

 

相关内容