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则为每个模块创建一个独立的作用域,避免全局作用域的污染。
相关推荐
木易士心6 分钟前
从 MVP 到千万级并发:AI 在前后端开发中的差异化落地指南
前端·后端
葡萄城技术团队8 分钟前
字体与打印:前端开发最常见的三个“为什么”
前端
王夏奇10 分钟前
python中的深浅拷贝和上下文管理器
java·服务器·前端
小杍随笔11 分钟前
【Rust 语言编程知识与应用:自定义数据类型详解】
开发语言·后端·rust
siger15 分钟前
徒手开荒-我用纯Nodejs+pnpm+monorepo改造了一个多vue2的iframe"微前端"项目
前端·node.js·前端工程化
lichenyang45316 分钟前
海克斯大乱斗攻略网站 —— 从零开发到云服务器部署全记录
前端
你的代码僚机19 分钟前
《别再被 SSO 骗了!前端单点登录原理+避坑指南》
前端
m0_5281744523 分钟前
C++中的代理模式变体
开发语言·c++·算法
皙然23 分钟前
深入理解 Java HashMap:从底层原理、源码设计到面试考点全解析
java·开发语言·面试
蜗牛会飞 202425 分钟前
大数据时代个人信息保护五大挑战
开发语言·华为云·个人开发·c5全栈