位置: 编程技术 - 正文

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 如何u盘启动
  • 代驾服务费如何计算
  • 净资产收益率怎么求
  • 净资产和净利润一样吗
  • 补缴企业所得税和滞纳金如何入账
  • 房产税的计税依据的形式包括
  • 出现巨石
  • 琼斯的大海怪
  • 公司借款利息可以用对公户转账吗
  • vue display
  • 如何用css设置图片大小
  • domain codomain range
  • thinkphp和php
  • 跨月的专用发票可以重新开吗
  • 出口退税管理类别四类
  • phpcms使用教程
  • 小规模纳税人广告税率是多少
  • 季初资产总额和季末资产总额怎么算
  • sqlserver2012安装后找不到
  • 水电费计提是什么意思
  • 入股投资的钱能取出来吗
  • 税收滞纳金能不能超过税款
  • 汇算清缴前跨年调账怎么调
  • 一般纳税人其他咨询服务税率
  • 以资抵债如何实现债权和物权的转
  • 加油充值卡开票内容是什么
  • 按公允价值入账的有哪些
  • 其他应付款转应付账款分录
  • 跨年度冲红字发票怎么冲
  • 金税盘维护费抵减分录
  • sql自定义变量
  • mysql搜索字段内容
  • mysql安装教程5.5安装好了在哪使用
  • rsyslog 8.11.0 (v8-stable) 发布
  • win10怎么设置pdf默认打开方式是wps
  • amd furyx
  • tcpsyncookies
  • win8系统出现蓝屏怎样处理
  • linux服务器dns配置
  • dell t110服务器
  • win7系统咋样
  • win10系统桌面怎么设置密码
  • linux 开启snmp
  • win7如何格式化D盘
  • win10周年版
  • 什么是四个菜
  • win8开始界面设置
  • [置顶] 关于UNITY5.0和高通AR4.2.3在手机上白屏的问题
  • jquery 上传进度
  • bat延迟1秒
  • 燃气号如何查询
  • 谈心谈话记录由谁填写
  • 民办非企业税务登记流程
  • 企业的赞助费如何入账
  • 干部任免审批表怎么填写
  • 实木地板什么
  • 登录上海电子税务局显示获取公告失败
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设