commonjs和esmodule

commonjs的模块导出和引用写法:

lib.js 导出一个模块

javascript 复制代码
let a = 1
let b = 2
function aPlus1() {
  return a++
}
module.exports = {
  a,b,aPlus1
}

index.js引用一个模块

javascript 复制代码
const {a,b,aPlus1} = require('./lib.js')
console.log('hh:',a)

esmodule的模块导出和引用方法:

lib.mjs

javascript 复制代码
export let a = 1
export let b = 2

index.mjs

javascript 复制代码
import {a,b} from './lib.mjs'

console.log(a)
console.log(b)

总结

commonjs使用require关键字来导入模块,使用module.exports来导出模块。

esmodule使用import {a} from './lib.mjs'来导入模块,使用export来导出模块。

存在的区别:

  • 模块加载和执行的时间点不同。CommonJS的模块在运行时加载和执行,而ES Module的模块在编译时就已经加载和执行。
  • 模块导出和导入的方式不同。CommonJS使用module.exports导出模块的输出,使用require导入其他模块。导出时,通常是创建一个值的副本,导入时,这个副本被修改不会影响导出的值。而ES Module使用export导出模块的输出,使用import导入其他模块。导出时,创建的是值的引用,因此对导出值的任何修改都会反映在导入模块中。
  • 模块作用域不同。在CommonJS中,模块内的代码运行在顶层作用域中,可能会污染全局作用域。而ES Module则为每个模块创建一个独立的作用域,避免全局作用域的污染。
相关推荐
十六年开源服务商4 分钟前
WordPress在线聊天系统推荐
大数据·javascript·html
张np5 分钟前
java基础-ListIterator 接口
java·开发语言
Apifox.12 分钟前
测试用例越堆越多?用 Apifox 测试套件让自动化回归更易维护
运维·前端·后端·测试工具·单元测试·自动化·测试用例
AndrewHZ16 分钟前
【Python与生活】怎么用python画出好看的分形图?
开发语言·python·生活·可视化·递归·分形
陳103017 分钟前
C++:继承
开发语言·c++
GSDjisidi18 分钟前
正社員・個人事業主歓迎|GSD東京本社で働こう|業界トップクラスの福利厚生完備
开发语言·面试·职场和发展
xiaoye-duck25 分钟前
C++ string 类使用超全攻略(下):修改、查找、获取及常见实用接口深度解析
开发语言·c++·stl
玉梅小洋27 分钟前
Chrome设置链接自动跳转新标签页而不是覆盖
前端·chrome
EndingCoder33 分钟前
反射和元数据:高级装饰器用法
linux·运维·前端·ubuntu·typescript
Tao____34 分钟前
可以本地部署的物联网平台
java·开发语言·物联网·mqtt·低代码