• xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!


    javascript module system all in one 

    AMD & CMD

    https://github.com/amdjs/amdjs-api/wiki/AMD

    http://requirejs.org/

    http://requirejs.org/docs/whyamd.html

    https://github.com/amdjs/amdjs-api/wiki/AMD-(%E4%B8%AD%E6%96%87%E7%89%88)

    https://github.com/cmdjs/specification/blob/master/draft/module.md

    https://github.com/seajs/seajs/issues/242

    Using jQuery UI with AMD

    http://learn.jquery.com/jquery-ui/environments/amd/

    AMD、CMD、UMD 模块的写法

    简介

    最近几年,我们可以选择的Javascript组件的生态系统一直在稳步增长。虽然陡增的选择范围是极好的,但当组件混合匹配使用时就会出现很尴尬的局面。开发新手们会很快发现不是所有组件都能彼此“和平相处”。

    为了解决这个问题,两种竞争关系的模块规范AMD和CommonJS问世了,它们允许开发者遵照一种约定的沙箱化和模块化的方式来写代码,这样就能避免“污染生态系统”。

    AMD

    随着RequireJS成为最流行的实现方式,异步模块规范(AMD)在前端界已经被广泛认同。

    下面是只依赖jquery的模块foo的代码:

    还有稍微复杂点的例子,下面的代码依赖了多个组件并且暴露多个方法:

    定义的第一个部分是一个依赖数组,第二个部分是回调函数,只有当依赖的组件可用时(像RequireJS这样的脚本加载器会负责这一部分,包括找到文件路径)回调函数才被执行。

    注意,依赖组件和变量的顺序是一一对应的(例如,jquery->$, underscore->_)。

    同时注意,我们可以用任意的变量名来表示依赖组件。假如我们把$改成$$,在函数体里面的所有对jQuery的引用都由$变成了$$。

    还要注意,最重要的是你不能在回调函数外面引用变量$和_,因为它相对其它代码是独立的。这正是模块化的目的所在!

    CommonJS

    如果你用Node写过东西的话,你可能会熟悉CommonJS的风格(node使用的格式与之相差无几)。因为有Browserify,它也一直被前端界广泛认同。

    就像前面的格式一样,下面是用CommonJS规范实现的foo模块的写法:

    还有更复杂的例子,下面的代码依赖了多个组件并且暴露多个方法:

    UMD: 通用模块规范

    既然CommonJs和AMD风格一样流行,似乎缺少一个统一的规范。所以人们产生了这样的需求,希望有支持两种风格的“通用”模式,于是通用模块规范(UMD)诞生了。

    不得不承认,这个模式略难看,但是它兼容了AMD和CommonJS,同时还支持老式的“全局”变量规范:


    保持跟上面例子一样的模式,下面是更复杂的例子,它依赖了多个组件并且暴露多个方法:

     

    1

    http://blog.gejiawen.com/2015/11/03/what-is-amd-cmd-commonjs-umd/

    http://davidbcalhoun.com/2014/what-is-amd-commonjs-and-umd/

    https://www.zhihu.com/question/20351507

    http://stackoverflow.com/questions/16521471/relation-between-commonjs-amd-and-requirejs

    阮一峰

    http://www.ruanyifeng.com/blog/2012/10/javascript_module.html

    http://www.ruanyifeng.com/blog/2012/10/asynchronous_module_definition.html

     CommonJS规范

    http://javascript.ruanyifeng.com/nodejs/module.html


    https://www.npmjs.com/package/ranma

    https://segmentfault.com/a/1190000004873947

    http://hao.jser.com/archive/7865/

    1

    1

    1

    1

    1

    1

    1

    1

     
  • 相关阅读:
    Apriori 算法-如何进行关联规则挖掘
    Nginx 常用命令
    Nginx Location匹配规则
    Nginx 负载均衡
    angular 路由传参的三种方式
    JAVA中final关键字的作用
    Python函数参数和注解是什么
    JMeter测试计划配置项解析
    JMeter元件作用域实践指南
    原来Python函数只是个对象
  • 原文地址:https://www.cnblogs.com/xgqfrms/p/5734496.html
Copyright © 2020-2023  润新知