博客专区 > 潘-C的博客 > 博客详情
关于CommonJS,AMD,CMD的初级理解
潘-C 发表于1年前
关于CommonJS,AMD,CMD的初级理解
  • 发表于 1年前
  • 阅读 83
  • 收藏 1
  • 点赞 2
  • 评论 0

330元/年抢阿里云香港云服务器,节省80%出海成本>>>   

摘要: 目前web前端开发中,模块化开发已经比较成熟,本人最近在学习组件化开发的一些理论和应用,比如React,其中的必要知识技能就是模块化,以前对这部分没有统一的认识和总结,翻了翻书籍和网上的一些资料,简单做一下区分,在以后的应用中,能各做其职。

之前接触到模块化开发,对这个概念的理解还是比较模糊,主要原因是实际应用中,几乎不用,或者很少用,碰到问题只会一股脑的拿起手中的锤子去锤,正确的解决方案一定是经过缜密思考和预言的结果。

先说这是三个东西产生的顺序是CommonJS,AMD,CMD。

1.CommonJS

     CommonJS是运行在服务器端、同步的、代表作品为NodeJS。

    对于服务器端的js脚本或者库文件来说,只是加载本地文件,所以同步和异步的差别几乎可以忽略,而同步加载更靠谱(这个词怪怪的)。运行过程中的核心对象是exports,所以我把CommonJS的关键字定义为"exports"。

2.AMD

    AMD是运行在浏览器端、异步的、代表作品为RequireJS。

    对于客户端来讲,加载服务器的js脚本或者库文件,如果是同步加载的话,就会产生延迟假死的想象,AMD的出现就是解决这个问题,它是RequireJS 在推广过程中对模块定义的规范化产出,AMD规范适用define方法定义模块,所以我把AMD的关键字定义为"define"。

3.CMD

    CMD的了解较少,是SeaJS 在推广过程中对模块定义的规范化产出,是在CommonJS和AMD的基础上产生的,跟AMD的主要区别是依赖原则不同,AMD是依赖前置,CMD则是依赖延迟。

对以前描述有理解偏差的,欢迎补充和提bug。

标签: 模块化 CommonJS AMD
共有 人打赏支持
粉丝 5
博文 12
码字总数 3908
×
潘-C
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
* 金额(元)
¥1 ¥5 ¥10 ¥20 其他金额
打赏人
留言
* 支付类型
微信扫码支付
打赏金额:
已支付成功
打赏金额: