Js前端模块化规范及其产品

规范一 commonJs:用于服务器端(产品有NodeJs、browserify等)。

javascript 复制代码
	// 导入
	var bjs = require("b.js")
	// 导出
	module.exports = function() {}

规范二 AMD:用于浏览器端,是异步的(产品有requireJs、jQuery、AngularJS、Dojo)。

  • AMD和RequireJS:RequireJS 是一个前端的模块化管理的工具库,遵循AMD规范。
  • AMD规范定义了一个自由变量或者说是全局变量 define 的函数。
AMD规范
javascript 复制代码
    define( id?, dependencies?, factory );    
    第一个参数 id 为字符串类型,表示了模块标识,为可选参数。若不存在则模块标识应该默认定义为在加载器中被请求脚本的标识。如果存在,那么模块标识必须为顶层的或者一个绝对的标识。
    第二个参数,dependencies ,是一个当前模块依赖的,已被模块定义的模块标识的数组字面量。
    第三个参数,factory,是一个需要进行实例化的函数或者一个对象。

规范三 CMD:用于浏览器端,是异步的(产品有Sea.js、Vue) 。

CMD规范
  1. 对于依赖的模块,AMD 是提前执行,CMD 是延迟执行。不过 RequireJS 从 2.0 开始,也改成可以延迟执行(根据写法不同,处理方式不同)。CMD 推崇 as lazy as possible.
  2. CMD 推崇依赖就近,AMD 推崇依赖前置。

四 UMD:通用模块

  • 用于在实际运行时探测用户实际使用的是 AMD 规范模块还是 CommonJS 规范模块。

五 ES6 Modules(Es6模块化语法,现在是大趋势):

javascript 复制代码
	// 导入
	import { time } from "./counter.mjs"
	// 导出
	export var time = 0
相关推荐
清汤饺子4 小时前
OpenClaw 本地部署教程 - 从 0 到 1 跑通你的第一只龙虾
前端·javascript·vibecoding
颜酱4 小时前
图的数据结构:从「多叉树」到存储与遍历
javascript·后端·算法
爱吃的小肥羊6 小时前
比 Claude Code 便宜一半!Codex 国内部署使用教程,三种方法任选一!
前端
IT_陈寒7 小时前
SpringBoot项目启动慢?5个技巧让你的应用秒级响应!
前端·人工智能·后端
树上有只程序猿8 小时前
2026低代码选型指南,主流低代码开发平台排名出炉
前端·后端
橙某人8 小时前
LogicFlow 小地图性能优化:从「实时克隆」到「占位缩略块」!🚀
前端·javascript·vue.js
高端章鱼哥8 小时前
为什么说用OpenClaw对打工人来说“不划算”
前端·后端
大脸怪8 小时前
告别 F12!前端开发者必备:一键管理 localStorage / Cookie / SessionStorage 神器
前端·后端·浏览器
Mr_Mao8 小时前
我受够了混乱的 API 代码,所以我写了个框架
前端·api
小徐_23338 小时前
向日葵 x AI:把远程控制封装成 MCP,让 AI 替我远程控制设备
前端·人工智能