码迷,mamicode.com
首页 > 其他好文 > 详细

模块化编程(三)---AMD

时间:2018-03-19 13:27:53      阅读:136      评论:0      收藏:0      [点我收藏+]

标签:str   define   math   影响   开发   工厂方法   说明   模块化编程   应该   

    AMD是"Asynchronous Module Definition"的缩写,意思就是"异步模块定义"。

   由于不是JavaScript原生支持,使用AMD规范进行页面开发需要用到对应的库函数,也就是大名鼎鼎RequireJS,实际上AMD 是 RequireJS 在推广过程中对模块定义的规范化的产出

   它采用异步方式加载模块,模块的加载不影响它后面语句的运行。所有依赖这个模块的语句,都定义在一个回调函数中,等到加载完成之后,这个回调函数才会运行。

 RequireJS主要解决两个问题

  • 多个js文件可能有依赖关系,被依赖的文件需要早于依赖它的文件加载到浏览器
  • js加载的时候浏览器会停止页面渲染,加载文件越多,页面失去响应时间越长

   RequireJs也采用require()语句加载模块,但是不同于CommonJS,它要求两个参数:

   第一个参数[module],是一个数组,里面的成员就是要加载的模块;第二个参数callback,则是加载成功之后的回调函数。math.add()与math模块加载不是同步的,浏览器不会发生假死。

   技术分享图片

   define()函数

 RequireJS定义了一个函数 define,它是全局变量,用来定义模块:
 define(id?, dependencies?, factory);
   参数说明:

  • id:指定义中模块的名字,可选;如果没有提供该参数,模块的名字应该默认为模块加载器请求的指定脚本的名字。如果提供了该参数,模块名必须是“顶级”的和绝对的(不允许相对名字)。

  • 依赖dependencies:是一个当前模块依赖的,已被模块定义的模块标识的数组字面量。
    依赖参数是可选的,如果忽略此参数,它应该默认为["require", "exports", "module"]。然而,如果工厂方法的长度属性小于3,加载器会选择以函数的长度属性指定的参数个数调用工厂方法。

  • 工厂方法factory,模块初始化要执行的函数或对象。如果为函数,它应该只被执行一次。如果是对象,此对象应该为模块的输出值。

     来举个??看看:

      技术分享图片

   RequireJs使用例子

 require.config是用来定义别名的,在paths属性下配置别名。然后通过requirejs(参数一,参数二);参数一是数组,传入我们需要引用的模块名,第二个参数是个回调函数,回调函数传入一个变量,代替刚才所引入的模块。

    技术分享图片

  引入模块也可以只写require()requirejs通过define()定义模块,定义的参数上同。在此模块内的方法和变量外部是无法访问的,只有通过return返回才行.

   技术分享图片

  将该模块命名为math.js保存。

   技术分享图片

  转自 https://www.jianshu.com/p/d67bc79976e6    前端模块化(CommonJs,AMD和CMD)

 

 

 

模块化编程(三)---AMD

标签:str   define   math   影响   开发   工厂方法   说明   模块化编程   应该   

原文地址:https://www.cnblogs.com/cutemantou/p/8600967.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!