位置: 编程技术 - 正文

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实现浏览器状态栏显示)

  • 缴纳印花税的会计科目
  • 企业间无偿划转资产,非关联方经营
  • 去年缴纳印花税忘记做账了怎么办呢
  • 申报过后财务报告怎么查
  • 筹建期间购买的机械配件
  • 预收款转营业外收入条件
  • 合并扣税金额是什么
  • 土地转让合同也叫什么
  • 制造费用结转生产成本金蝶怎么操作
  • 实收资本转出计入什么科目
  • 企业自用房要交契税吗
  • 意外死亡公司赔偿多少标准
  • 没有业务来往可以报税吗
  • 股票印花税怎么交
  • 征收开票信息
  • 企业爱心捐赠可以抵相应的税吗
  • 向员工发放用餐费的通知
  • 企业公司报税流程
  • 企业注销时资本公积怎么处理
  • 美元兑人民币分时走势图
  • 人力资源外包公司发展前景
  • 王者荣耀如何充值退款
  • 鸿蒙大文件夹怎么设置透明度
  • 如何彻底关闭电脑右下角弹窗
  • 无形资产入账包括增值税吗
  • 植物租赁方案
  • mac电脑新手使用
  • win10没有音效设置
  • win10双系统删除linux
  • 大沙丘上的日落图片
  • 处理固定资产怎么交税
  • json字符串转json js
  • 红字发票进项转出当期
  • 实际出资大于注册资金
  • vuexl
  • axios发送多个请求
  • 大学生创新创业大赛官网
  • 买商品赠送赠品怎么做账
  • python多态的概念
  • 报销的注意事项
  • 加速折旧法是指在固定资产使用的早期少提折旧
  • 企业向银行借入长期借款,应借记
  • win2008r2服务器文件无法进入软件
  • 红冲发票是什么影响
  • 以前年度损益调整会计分录
  • 简易征收预缴税率怎么算
  • 奖金偶然所得税起征点
  • 稳岗返还计入营业外收入
  • 不是公司的车费用能走公司吗
  • 零工发生事故算工伤吗
  • 银行承兑汇票提示付款期限
  • 小规模开专票的税点是多少
  • 企业实收资本怎么计算
  • 建筑施工企业涉诉案件多的原因
  • 两家公司
  • sql语句错误提示
  • mysql怎么修改my.ini
  • 如何快速提升花呗额度
  • windowsxp教程
  • linux中使用mkdir命令创建新的目录时
  • win10周年纪念版
  • ubuntu如何安装wps
  • crossfire.exe是什么
  • dmidecode 硬盘
  • w10qq图标不显示
  • cocos2dx入门
  • 实例的英文
  • node链接数据库
  • 深入了解求助者时,首先要进行工作是
  • 如何关闭危险端口
  • 网页css加载失败
  • javascript模块化规范
  • easyui 表单提交
  • python smtplib模块详解
  • 税务局试用期
  • 个人所得税代扣代缴手续费退库申请
  • 建筑企业外地施工预缴税款
  • 安康国税局电话号码
  • 广东省电子税务局app
  • 地税局网上报税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设