【工程化】CJS 和 ESM

common js

require 函数的原理伪代码:

function require(path) {
    if (该模块有缓存) {
        return 该模块的缓存
    }
    function _run(exports, require, module, __filename, __dirname) {
        // 模块代码
    }
    // module.exports 即为模块导出的对象
    var module = { exports: {} };
    _run.call(module.exports, module.exports, require, module, __filename, __dirname);
    // 将 module.exports 加入缓存
    return module.exports;
}
console.log(arguments.length)  // 5 // 刚好是 _run 的五个参数
console.log(this)  // {}

使用require:

const m = require('./1')
console.log(m)  // { a: 1, b: 2 }
this.a = 1
this.b = 2  // 等同于 exports.b = 2 或者 module.exports.b = 2
// 或者也可以直接 将 a, b 都放入对象中 统一  module.exports = {a: 1, b: 2}

es module

// 静态依赖
import a from './a.js'

// 动态依赖
import('./a.js').then(m => {
    console.log(m) // m 就是 ./a.js 导出的模块
})

export default 'hello world' // 默认导出
export const a = 123 // 具名导出

符号绑定:

image.png

image.png

区别

  1. CMJ 是社区标准,ESM 是官方标准
  2. CMJ 是使用API实现的模块化,ESM 是使用新语法实现的模块化
  3. CMJ 仅在node环境中支持,ESM 各种环境均支持
  4. CMJ 是动态的依赖,同步执行。ESM 既支持动态,也支持静态(只能写在模块的最顶部,在代码运行前就要确定依赖关系),动态依赖是异步执行的。
  5. ESM 导入时有符号绑定(直接导入引用,所以对引用进行操作,原模块也会跟着改变),CMJ 只是普通函数调用和赋值
  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小秀_heo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值