本文摘自PHP中文网,作者不言,侵删。
本篇文章给大家带来的内容是关于JavaScript中AMD和ES6模块导入导出的比较(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。我们前端在开发过程中经常会遇到导入导出功能,
在导入时,有时候是require,有时候是import
在导出时,有时候是exports,module.exports,有时候是export,export default
今天我们对这些内容进行简单的介绍
import,export,export default
import,export,export default属于ES6规范
import
import 是在编译过程中执行
也就是说是在代码执行前执行,
比如说,import后面的路径写错了,在运行代码前就会抛错,
在编写代码时,import不是一定要写在js的最前面
import命令具有提升效果,会提升到整个模块的头部,首先执行。(是在编译阶段执行的)
import是静态执行的
因为import是静态执行的,不能使用表达式和变量,即在运行时才能拿到结果的语法结构
比如,不能再if和else中使用import
再比如,import后的from的路径,可以是相对路径,可以是绝对路径,但是不能是根据变量得来的路径
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
|
import可以使用as进行重命名
import 的有很多种导入方式,
1 2 3 4 5 6 |
|
导入的方式和导出有些关联,我们在下面说导出的时候,对以上这些导入方式进行逐一介绍
exoprt和export default
将exoprt和export default放在一起,因为它们关联性很大
简单说:export是导出,export default是默认导出
一个模块可以有多个export,但是只能有一个export default,export default可以和多个export共存
export default 为默认导出,导出的是用{}包裹的一个对象,以键值对的形式存在
导出的方式不同,导入的方式也就不同,
所以建议同一个项目下使用同一的导入导出方式,方便开发
export default解构以后就是export
通过两个直观的demo看下export和export default的区别
先看一段代码(export)
output.js
1 2 |
|
input.js
1 2 |
|
留意上面的代码其中export {a}导出的a,和import {a}导入的a是同一个a
再看一段代码(export default)
1 2 |
|
input.js
1 2 |
|
看下export default的栗子中的input.js,我们稍作改动
1 2 |
|
我们做了些改动,但是输出没有变化,import导入的是export default下的对象,叫什么名字都可以,因为只会存在一个export default
exoprt和export default混合使用
exoprt和export default在同一个模块中同时使用,是支持的,虽然我们一般不会这么做
看一个栗子
output.js
1 2 3 4 5 6 7 8 9 10 |
|
input.js
1 2 3 4 |
|
as 重命名
通过 exoprt和export default导出的在import引入时都支持通过as进行重命名
看个栗子
还是上面的那个output.js
1 2 3 4 5 6 7 8 9 10 |
|
input.js
1 2 3 4 5 |
|
as后面的变量是你要在input.js中使用的
重点看这一部分
1 2 3 |
|
- 代表了所有,包括了export和export default导出的
我们之前说import{}和export{},是一一对应关系,所以在export导出的,在import{}不支持使用*
关于 import,export,export default先介绍到这里,我们继续
require,exports,module.exports(记得后面的s)
这是 AMD规范
require
require是运行时调用,所以require理论上可以运用在代码的任何地方
require支持动态引入
例如,这样是支持的
1 2 3 4 5 |
|
require路径支持变量
1 2 3 4 5 6 |
|
通过require引入,是一个赋值的过程
exports 与 module.exports
根据AMD规范
每个文件就是一个模块,有自己的作用域。在一个文件里面定义的变量、函数、类,都是私有的,对其他文件不可见。
每个模块内部,module变量代表当前模块。这个变量是一个对象,它的exports属性(即module.exports)是对外的接口。加载某个模块,其实是加载该模块的module.exports属性。
为了方便,Node为每个模块提供一个exports变量,指向module.exports。这等同在每个模块头部,有一行这样的命令。
1 |
|
所以说
以下两种写法等价
1 2 |
|
前面说在每个模块提供一个exports变量,指向module.exports。
所以不能直接给exports赋值,赋值会覆盖
1 |
|
直接给exports赋值会切断exports和 module.exports的关联关系
看一个栗子
output.js
1 2 3 4 5 6 |
|
input.js
1 2 |
|
继续看代码
output.js
1 2 3 |
|
input.js
1 2 |
|
再看一段代码
output.js
1 2 3 |
|
input.js
1 2 |
|
当直接给 module.exports时,exports会失效
交叉使用
在ES6中export default 导出的是一个对象
在AMD中exports和module.exports导出的也都是一个对象
所以如果你手中的项目代码支持两种规范,那么事可以交叉使用的(当然不建议这么去做)
通过export导出的不一定是一个对象
demo1
output.js
1 2 3 |
|
inputj.s
1 2 3 4 |
|
demo2
output.js
1 2 3 4 5 6 7 8 9 |
|
input.js
1 2 |
|
总结
- require,exports,module.export属于AMD规范,import,export,export default属于ES6规范
- require支持动态导入,动态匹配路径,import对这两者都不支持
- require是运行时调用,import是编译时调用
- require是赋值过程,import是解构过程
- 对于export和export default 不同的使用方式,import就要采取不同的引用方式,主要区别在于是否存在{},export导出的,import导入需要{},导入和导出一一对应,export default默认导出的,import导入不需要{}
- exports是module.export一种简写形式,不能直接给exports赋值
当直接给module.export赋值时,exports会失效
本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注PHP中文网的JavaScript视频教程栏目!
以上就是JavaScript中AMD和ES6模块导入导出的比较(代码示例)的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
更多相关阅读请进入《javascript》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者