位置: 编程技术 - 正文

JavaScript模块规范之AMD规范和CMD规范(javascript模板)

编辑:rootadmin

推荐整理分享JavaScript模块规范之AMD规范和CMD规范(javascript模板),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:js模块是什么意思,js模块化原理及实现过程,js模块化原理及实现过程,js模块化开发教程,js的模块化可以怎么做,JavaScript模块规范,js 模块 modules,JavaScript模块规范,内容如对您有帮助,希望把文章链接给更多的朋友!

模块化是指在解决某一个复杂问题或者一系列的杂糅问题时,依照一种分类的思维把问题进行系统性的分解以之处理。模块化是一种处理复杂系统分解为代码结构更合理,可维护性更高的可管理的模块的方式。可以想象一个巨大的系统代码,被整合优化分割成逻辑性很强的模块时,对于软件是一种何等意义的存在。对于软件行业来说:解耦软件系统的复杂性,使得不管多么大的系统,也可以将管理,开发,维护变得“有理可循”。

还有一些对于模块化一些专业的定义为:模块化是软件系统的属性,这个系统被分解为一组高内聚,低耦合的模块。那么在理想状态下我们只需要完成自己部分的核心业务逻辑代码,其他方面的依赖可以通过直接加载被人已经写好模块进行使用即可。

一、AMD

AMD就只有一个接口:define(id&#;,dependencies&#;,factory);

它要在声明模块的时候制定所有的依赖(dep),并且还要当做形参传到factory中,像这样:

要是没什么依赖,就定义简单的模块,下面这样就可以啦

这里有define,把东西包装起来,那Node实现中怎么没看到有define关键字呢,它也要把东西包装起来,其实,只是Node隐式包装了而已..

RequireJS就是实现了AMD规范的

二、CMD

玉伯写了seajs,就是遵循他提出的CMD规范,比AMD稍微强大点,用起来感觉也方便些

三、AMD与CMD的区别

CMD相当于按需加载,定义一个模块的时候不需要立即制定依赖模块,在需要的时候require就可以了,比较方便;而AMD则相反,定义模块的时候需要制定依赖模块,并以形参的方式引入factory中

//AMD方式定义模块

//CMD

而SEAJS也有use功能也是需要先引入所有依赖的模块,如

四、插件支持

但全球有两种比较流行的 JavaScript 模块化体系,一个是 Node 实现的 CommonJS,另外一个是 AMD。很多类库都同时支持 AMD 和 CommonJS,但是不支持 CMD。或许国内有很多 CMD 模块,但并没有在世界上流行起来。

JavaScript模块规范之AMD规范和CMD规范(javascript模板)

现在比较火的 React 及周边类库,就是直接使用 CommonJS 的模块体系,使用 npm 管理模块,使用 Browserify 打包输出模块。不久的将来 ES6 中新的模块化标准,可能就都得遵循新的标准了,什么AMD、CMD可能到时也不会怎么用了。

但是目前来说,前端开发没有用模块化编程就真的out的了,而目前的模块化编程,本人还是建议用SEAJS,虽然很多插件需要追加或修改一小块代码才能支持。但改过一次就能反复使用,也不会影响其它标准的支持。总体还算是比较方便实用的。

单独解释AMD 与 CMD 区别到底在哪里?

看了以上 AMD,requireJS 与 CMD, seaJS的简单介绍会有点感觉模糊,总感觉较为相似。因为像 requireJS 其并不是只是纯粹的AMD固有思想,其也是有CMD规范的思想,只不过是推荐 AMD规范方式而已, seaJS也是一样。

下面是玉伯对于 AMD 与 CMD 区别的解释:

AMD 是 RequireJS 在推广过程中对模块定义的规范化产出。

CMD 是 SeaJS 在推广过程中对模块定义的规范化产出。

类似的还有 CommonJS Modules/2.0 规范,是 BravoJS 在推广过程中对模块定义的规范化产出还有不少&#;&#;

这些规范的目的都是为了 JavaScript 的模块化开发,特别是在浏览器端的。

目前这些规范的实现都能达成浏览器端模块化开发的目的。

区别:

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

2. CMD 推崇依赖就近,AMD 推崇依赖前置。看代码:

// CMD

// AMD 默认推荐的是

虽然 AMD 也支持 CMD 的写法,同时还支持将 require 作为依赖项传递,但 RequireJS 的作者默认是最喜欢上面的写法,也是官方文档里默认的模块定义写法。

3. AMD 的 API 默认是一个当多个用,CMD 的 API 严格区分,推崇职责单一。比如 AMD 里,require 分全局 require 和局部 require,都叫 require。CMD 里,没有全局 require,而是根据模块系统的完备性,提供 seajs.use 来实现模块系统的加载启动。

CMD 里,每个 API 都简单纯粹。

4. 还有一些细节差异,具体看这个规范的定义就好,就不多说了。

JS实现浏览器状态栏显示时间的方法 本文实例讲述了JS实现浏览器状态栏显示时间的方法。分享给大家供大家参考,具体如下:以前做个人主页的时候,总喜欢把自己的网页搞的很个性,在

JS实现浏览器状态栏文字闪烁效果的方法 本文实例讲述了JS实现浏览器状态栏文字闪烁效果的方法。分享给大家供大家参考,具体如下:这里演示为你的IE浏览器状态栏增加文字闪烁效果,请看

JS基于Ajax实现的网页Loading效果代码 本文实例讲述了JS基于Ajax实现的网页Loading效果代码。分享给大家供大家参考,具体如下:这是一款很不错的网页Loading效果,常用于Ajax交互式网页设计

标签: javascript模板

本文链接地址:https://www.jiuchutong.com/biancheng/382666.html 转载请保留说明!

上一篇:JS实现浏览器状态栏文字从右向左弹出效果代码(js浏览器运行机制)

下一篇:JS实现浏览器状态栏显示时间的方法(js实现浏览器状态栏显示)

  • 企业自建房产缴契税吗
  • 增值税审核表
  • 清卡抄税报税顺序
  • 怎么理解财务会计与管理会计
  • 辞退福利是指
  • 经营范围没有的可以开票吗
  • 增值税专用发票可以开电子发票吗
  • 劳务公司劳务工资做什么科目
  • 增值税进项税转出所得税调整吗
  • 返聘已退休人员是否需要缴纳社保
  • 税收滞纳金计税吗
  • 商品损失 进项税 确定
  • 广告公司好进吗
  • 报销单和付款单的区别
  • 用外购存货投资分录怎么写?
  • 土地承包经营合同无效情形
  • 专用发票扣税
  • 销售货物收入与营业收入
  • 资产负债表季度申报期末余额怎么填
  • 资产负债表中资产总计和负债所有者权益不平等
  • 发票上可以盖两次章吗
  • 电子票据查询打印
  • 外籍个税起征点
  • 专用发票离线限额是什么意思
  • 增值税留抵税额账务处理
  • 0元收购股份
  • 应付的工资属于什么科目
  • 委托代付工程款会计分录
  • 转让二手宾馆需要注意事项
  • 加速折旧法和直线折旧法的区别
  • 外贸企业国内运费可以抵扣吗
  • 预计负债是什么原则
  • 文化事业建设税计税依据是
  • 跨区域涉税事项报告表报验流程
  • 搜索框无法搜索内容
  • 对公账户自己扣钱
  • 应纳所得税额税率表
  • php的魔术函数
  • 企业筹建期发生的费用有哪些
  • 票折怎么操作
  • mysql php
  • php获取服务端ip
  • 代缴社保可以领住房补贴吗
  • 从银行提取现金50000元备发工资
  • 数量金额式账页图片
  • 企业转让无形资产取得的收益应计入营业外收入
  • 残保金属期是当年还是上年
  • 企业所得税的扣除是什么意思
  • access不能打开数据库
  • 物业管理企业会计核算的特点如何?
  • 财政专户资金支出
  • 普通发票和增值税发票报销有什么区别?
  • 增值税销项税额抵减账务处理
  • 以土地出资的税费怎么算
  • 事业单位结余是什么意思
  • 政府给的专款专用的补助,怎么入账
  • 退回的企业所得税计入什么科目
  • 预缴税款的会计处理
  • sql的理解
  • mysql 备份和恢复
  • Windows10下MySQL5.7.19安装教程 MySQL忘记root密码修改方法
  • fedora系统怎么样
  • xp从装系统
  • 图解在OS X中管理窗口大小的多种方法
  • linux find . -name命令
  • linux使用mv命令,结果文件不见了
  • unity 移动应用开发
  • Unity3D游戏开发引擎
  • 批处理/s
  • Node.js中的construct构造函数
  • nodejs libuv
  • 字符串截取用什么方法
  • javascript教程
  • ubuntu修改默认桌面环境
  • js异步实现原理
  • jquery动态生成页面
  • jqueryfor
  • Python调用大漠插件
  • 劳务派遣服务计税
  • 辽宁国税征期日历
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设