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则为每个模块创建一个独立的作用域,避免全局作用域的污染。
相关推荐
lightqjx几秒前
【前端】前端学习二之CSS
前端·css·学习·html
IT东几秒前
Vue 多环境部署全解析:解决测试与生产一致性难题
前端·javascript·vue.js
chushiyunen3 分钟前
python实现分离不同人声、wespeaker
开发语言·python
想不明白的过度思考者4 分钟前
SpringAOP:Java 三大代理模式:从静态代理到 JDK & CGLIB 动态代理
java·开发语言·代理模式
of Watermelon League5 分钟前
Redis 通用命令
前端·redis·bootstrap
chxii5 分钟前
配置Nginx 的 Keepalive 提升每秒查询率(QPS)
前端·nginx
xnkyn7 分钟前
frp内网穿透https访问本地服务,frpee客户端https教程
前端·后端·网络协议·http·https
AI自动化工坊8 分钟前
Claw Code技术深度解析:Python+Rust混合架构的设计与实现
开发语言·人工智能·python·ai·架构·rust·开源
妙蛙种子3119 分钟前
【Java设计模式 | 创建者模式】单例模式
java·开发语言·后端·单例模式·设计模式
一叶之秋141210 分钟前
类型驱动:解锁Qt模板的渲染潜能
开发语言·qt