javascript的模块化是什么_CommonJS和ES6模块有何不同?

admin 百科 11
JavaScript模块化将代码拆分为独立可复用单元,解决全局污染、命名冲突与依赖混乱问题;CommonJS运行时加载、值拷贝导出、Node原生支持;ES6模块编译时静态分析、活绑定导出、浏览器和Node均原生支持。

javascript的模块化是什么_CommonJS和ES6模块有何不同?-第1张图片-佛山资讯网

JavaScript 模块化,就是把代码按功能拆成独立、可复用的单元,每个单元有自己作用域,不污染全局,还能明确声明“我提供什么”和“我需要什么”。它解决的是早期 JS 全局变量乱飞、命名冲突、依赖不清、难维护的老大难问题。

语法写法不一样

CommonJS 用 require()module.exports(或 exports):

  • 导出:可以是对象、函数、值,比如 module.exports = { add, name }exports.add = add
  • 导入:const math = require('./math'),支持解构但属于运行时行为

ES6 模块用 importexport

  • 导出:支持命名导出(export const a = 1)、默认导出(export default function())、重命名导出等
  • 导入:必须在顶层,不能放在 if 或函数里;支持静态解构,如 import { add } from './math.js'

加载时机和依赖分析方式不同

CommonJS 是运行时加载

立即学习“Java免费学习笔记(深入)”;

  • require() 执行时才去读文件、执行模块代码、返回 module.exports
  • 路径可以是表达式,支持动态加载:require('./' + env + '.js')
  • 无法在编译阶段知道依赖树,工具难做深度优化

ES6 模块是编译时静态分析

  • import 语句在代码解析阶段就被提取,依赖关系一目了然
  • 因此支持 Tree Shaking(自动剔除未使用的导出)、类型推断、打包优化
  • 不允许动态路径,if (...) { import('./a.js') } ❌ 必须用 import('./a.js') 动态函数调用(返回 Promise)

导出值的行为本质不同

CommonJS 导出的是值的拷贝

标签: javascript es6 java js node.js node 浏览器 工具 作用域

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~