js模块系统require和import区别与联系

举报
彭世瑜 发表于 2021/08/14 01:04:42 2021/08/14
【摘要】 模块加载原理 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

参考 深入理解CommonJS!

其他文章

  1. require,import区别?

文章来源: pengshiyu.blog.csdn.net,作者:彭世瑜,版权归原作者所有,如需转载,请联系作者。

原文链接:pengshiyu.blog.csdn.net/article/details/102544172

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。