js模块系统require和import区别与联系
【摘要】 模块加载原理
var module = {
exports: {}
};
(function(module, exports) {
exports.multiply = function (n) { return n * 1000 };
}(module, module.exports))
var f = module.exports.multiply;
...
模块加载原理
var module = {
exports: {}
};
(function(module, exports) {
exports.multiply = function (n) { return n * 1000 };
}(module, module.exports))
var f = module.exports.multiply;
f(5) // 5000
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
require和import
1、区别
require / exports 是 CommonJS(在Node中实现)
import / export 是 ES2015 的模块
require是动态加载
import是静态加载
2、联系
import -> babel打包 -> require
CommonJS 格式转换的工具: http://browserify.org/
3、示例
require
// 引入
const fs = require('fs')
// 导出
exports.fs = fs
module.exports = fs
- 1
- 2
- 3
- 4
- 5
- 6
import
// 引入
import fs from 'fs'
import {readFile} from 'fs'
// 导出
export default fs
export const fs
export function readFile
export {readFile, read}
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
exports 和 module.exports
exports 只能使用.语法向外暴露内部变量
例 exports.xxx=xxx
module.exports既可以通过点语法,也可以直接赋值一个对象
例 module.exports.xxx=xxx
其他文章
文章来源: pengshiyu.blog.csdn.net,作者:彭世瑜,版权归原作者所有,如需转载,请联系作者。
原文链接:pengshiyu.blog.csdn.net/article/details/102544172
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)