HTML5技术

require.js入门 - 爱喝酸奶的吃货

字号+ 作者:H5之家 来源:H5之家 2017-04-14 13:05 我要评论( )

小颖目前所在的公司在用require.js,小颖一直说要写个小demo,今天抽空把自己写的小demo分享出来,希望对初学者有一些帮助,嘻嘻 学习资料: CSDN上的一篇文章:使用RequireJS优化Web应用前端 阮一峰老师的网络日志:Javascript模块化编程(三):require.js

    小颖目前所在的公司在用require.js,小颖一直说要写个小demo,今天抽空把自己写的小demo分享出来,希望对初学者有一些帮助,嘻嘻

    学习资料:

                 CSDN上的一篇文章:使用RequireJS优化Web应用前端

                 阮一峰老师的网络日志:Javascript模块化编程(三):require.js的用法

                 卷柏的花期的随笔:requireJS 从概念到实战

    demo目录:

                                       

    小颖就不在自己博客里卖弄了,像:为什么要用require.js?、require.js的加载、主模块的写法等小颖就不在我的博客里面写了,详细的大家请移步到:阮一峰老师的网络日志:Javascript模块化编程(三):require.js的用法中去看看。小颖就主要给大家分享下小颖理解的  require.js模块的加载和AMD模块的写法  

在看小颖写的demo之前大家先看下阮一峰老师的网络日志:Javascript模块化编程(三):require.js的用法中模块的加载和AMD模块的写法的详解:

模块的加载:

    上一节最后的示例中,主模块的依赖模块是['jquery', 'underscore', 'backbone']。默认情况下,require.js假定这三个模块与main.js在同一个目录,文件名分别为jquery.js,underscore.js和backbone.js,然后自动加载。

    使用require.config()方法,我们可以对模块的加载行为进行自定义。require.config()就写在主模块(main.js)的头部。参数就是一个对象,这个对象的paths属性指定各个模块的加载路径。

require.config({     paths: {       "jquery": "jquery.min", "underscore": "underscore.min", "backbone": "backbone.min"     }   });

  上面的代码给出了三个模块的文件名,路径默认与main.js在同一个目录(js子目录)。如果这些模块在其他目录,比如js/lib目录,则有两种写法。一种是逐一指定路径。

require.config({     paths: {       "jquery": "lib/jquery.min", "underscore": "lib/underscore.min", "backbone": "lib/backbone.min"     }   });

另一种则是直接改变基目录(baseUrl)。

require.config({     baseUrl: "js/lib",     paths: {       "jquery": "jquery.min",       "underscore": "underscore.min",       "backbone": "backbone.min"     } });

如果某个模块在另一台主机上,也可以直接指定它的网址,比如:

require.config({     paths: {       "jquery": "https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min"     } });

require.js要求,每个模块是一个单独的js文件。这样的话,如果加载多个模块,就会发出多次HTTP请求,会影响网页的加载速度。因此,require.js提供了一个优化工具,当模块部署完毕以后,可以用这个工具将多个模块合并在一个文件中,减少HTTP请求数。

AMD模块的写法

     require.js加载的模块,采用AMD规范。也就是说,模块必须按照AMD的规定来写。

     具体来说,就是模块必须采用特定的define()函数来定义。如果一个模块不依赖其他模块,那么可以直接定义在define()函数之中。

     假定现在有一个math.js文件,它定义了一个math模块。那么,math.js就要这样写:

  // math.js   define(function (){     var add = function (x,y){       return x+y;     };     return {       add: add     };   });

加载方法如下:

  // main.js   require(['math'], function (math){     alert(math.add(1,1));   });

如果这个模块还依赖其他模块,那么define()函数的第一个参数,必须是一个数组,指明该模块的依赖性。

  define(['myLib'], function(myLib){     function foo(){       myLib.doSomething();     }     return {       foo : foo     };   });

当require()函数加载上面这个模块的时候,就会先加载myLib.js文件。

大家再来看看小颖写的代码:

1.index.html

require.js小demoUsernamePasswordSign in

2.app.js

requirejs.config({ baseUrl: 'js/lib', paths: { jquery: '../jquery' } }); require(['main', 'jquery'], function(mains, jq) { jq('#logBtn').click(function() { var logon = mains.logon(jq('#logBtn').val(), jq('#inputPassword').val()); if (logon) { alert('登陆成功!'); } else { alert('登陆失败!'); } }); });

3.js/lib下的main.js

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • Docker基础入门及示例 - KevinCC

    Docker基础入门及示例 - KevinCC

    2017-03-16 12:01

  • 小白学习H5从入门到放弃 - strength小宝

    小白学习H5从入门到放弃 - strength小宝

    2017-02-27 16:01

  • Qt入门之基础篇 ( 一 ) :Qt4及Qt5的下载与安装 - CN_Simo

    Qt入门之基础篇 ( 一 ) :Qt4及Qt5的下载与安装 - CN_Simo

    2017-01-27 09:00

  • 【第二篇】ASP.NET MVC快速入门之数据注解(MVC5+EF6) - 三生石上

    【第二篇】ASP.NET MVC快速入门之数据注解(MVC5+EF6) - 三生石上

    2016-12-27 13:00

网友点评