小颖目前所在的公司在用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

<!DOCTYPE html>
<html> <head>
<meta charset="utf-8">
<title>require.js小demo</title>
<link rel="stylesheet" href="css/bootstrap.css">
<link rel="stylesheet" href="css/base.css">
<!-- 加载require.js文件,也可能造成网页失去响应。解决办法有两个,一个是把它放在网页底部加载,另一个是写成下面这样: -->
<!-- <script src="js/require.js" defer async="true" ></script> -->
<!--async属性表明这个文件需要异步加载,避免网页失去响应。IE不支持这个属性,只支持defer,所以把defer也写上。 -->
<!-- 加载require.js以后,下一步就要加载我们自己的代码了。假定我们自己的代码文件是main.js,也放在js目录下面。只需要写成下面这样就行了: -->
<!-- <script src="js/require.js" data-main="src/main.js"></script> -->
<script defer async="true" data-main="app" src="js/require.js"></script>
</head> <body>
<div class="div-index">
<div class="index-content">
<form class="form-horizontal">
<div class="form-group">
<label class="col-sm-2 col-xs-2 control-label">Username</label>
<div class="col-sm-5 col-xs-5">
<input type="text" class="form-control" id="inputUserName" placeholder="Username">
</div>
</div>
<div class="form-group">
<label class="col-sm-2 col-xs-2 control-label">Password</label>
<div class="col-sm-5 col-xs-2">
<input type="password" class="form-control" id="inputPassword" placeholder="Password">
</div>
</div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-5 col-xs-5">
<button type="submit" class="btn btn-default" id='logBtn'>Sign in</button>
</div>
</div>
</form>
</div>
</div> </body> </html>

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

define(function() {
var logon = function(userName, password) {
if (userName === '小颖' && password === '1028') {
return true;
} else {
return false;
}
};
return {
logon: logon
}
});

1.小颖的基目录是:baseUrl: 'js/lib',大家看了阮一峰分享的日志应该对   baseUrl   也有所了解,小颖理解的  baseUrl  就是 如果你要调用很多一个目录下的js,那么你就将这个目录定位基目录,

2.paths:如果你在paths中引了你要用的js,那么后面你要用的时候只直接调用就好了,比如上面的app.js中,小颖在paths中已经引了jquery.js,所以在用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('登陆失败!');
}
});
});

小颖用AMD规范写法,加载了main.js和jquery.js,并在回调函数中用  mains 和 jq 代表他们。如果上面的示例不够明了,大家看看下面这个:

app.js

requirejs.config({
baseUrl: 'js/lib',
paths: {
jquery: '../jquery'
}
});
require(['main'], function(mains) {
console.log('调用main.js');
});

main.js

define(['jquery'], function(jq) {
jq('#logBtn').click(function() {
var _logon = logon(jq('#inputUserName').val(), jq('#inputPassword').val());
if (_logon) {
alert('登陆成功!');
} else {
alert('登陆失败!');
}
});
var logon = function(userName, password) {
if (userName === '小颖' && password === '1028') {
return true;
} else {
return false;
}
};
return {
logon: logon
}
});

如果只定义了基目录而没有在paths中引用jquery,那么当需要用jquery的时候,需要通过调用jquery的目录下的jquery.js,才能调用,不能直接调用:

app.js

requirejs.config({
baseUrl: 'js/lib',
paths: {
// jquery: '../jquery'
}
});
require(['main'], function(mains) {
console.log('调用main.js');
});

main.js

define(['../jquery'], function() {
$('#logBtn').click(function() {
var _logon = logon($('#inputUserName').val(), $('#inputPassword').val());
if (_logon) {
alert('登陆成功!');
} else {
alert('登陆失败!');
}
});
var logon = function(userName, password) {
if (userName === '小颖' && password === '1028') {
return true;
} else {
return false;
}
};
return {
logon: logon
}
});

好啦,小颖的分享到这里就结束啦,希望对大家有所帮助,明天就是礼拜五啦,哈哈哈哈,后天就是周末啦,提前祝大家周末愉快哦!!!嘻嘻

require.js入门的更多相关文章

  1. require.js 入门笔记

    网站越来越庞大,JS也是越写越多. 当所有的JS 都集中在 HTML的 head 部分时,网页加载变得很慢,很多的 JS代码也并不是全都适用在当前的页面,造成了代码的冗余度非常高. 而且长长的JS代码 ...

  2. require.js 入门学习 (share)

    以下内容转自阮一峰老师的网络日志:http://www.ruanyifeng.com/blog/2012/11/require_js.html 更多学习资源: require.js官网:http:// ...

  3. require.js入门指南(三)

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  4. require.js入门指南(二)

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  5. require.js入门指南(一)

    *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: 0 !important; } /* ...

  6. require.js 入门学习-备

    一.为什么要用require.js? 最早的时候,所有Javascript代码都写在一个文件里面,只要加载这一个文件就够了.后来,代码越来越多,一个文件不够了,必须分成多个文件,依次加载.下面的网页代 ...

  7. 模块化 require.js 入门教学(前端必看系列)

    在工作的时候总是会用到模块化开发,那接下来我就顺着这个问题来说一下什么是模块化 前端模块化 !!! JS 模块化提供给我们三种规范 分别就是 No.1 commonjs  这个其实也就代表了node. ...

  8. require.js疑惑

    昨天小颖分享了一篇require.js入门 ,今天小颖发现了一个很郁闷的问题,希望大神们帮小颖解释下到底是什么原理才能出现以下的现象,其实小颖昨天也有问过园友里的一位帅锅,只是他解释的小颖没太明白.嘻 ...

  9. require.js简单入门

    推荐文章:http://www.ruanyifeng.com/blog/2012/11/require_js.html 1.以下例子主要实现功能, 1)引用jq库获取dom中元素文本, 2)实现并引用 ...

随机推荐

  1. Java系统属性与Preferences API的简单介绍

    系统属性在和Preferences API都是键值对,前者只能当前应用程序中共享数据,而后者可以在用户的各个应用或用户之间共享数据. 系统属性 Java 的系统属性决定了 Java 程序实际运行的环境 ...

  2. 从覆盖bootstrap样式谈css选择器优先级

    样式优先级 首先简单说几个定义样式的方式: 元素内嵌: <li><a href="" style="color:#ffffff;">SH ...

  3. div 宽高相等2种实现方式

    div.wh{ background:#ff0;width:50%;position:relative;display:inline-block; } div.wh:before{ content: ...

  4. python--对函数的理解

    函数的定义 def functionname(arg): Suite Return [expression] 1.def 定义函数时的关键字 2.functionname 函数名 3.arg函数的参数 ...

  5. QtQuick 中的 qml 与 Qt 的 C++

    QtQuick 可以使用内置的 JavaScript 引擎加载相应的 JS 代码,使用起来特别方便. 在 Qt 中使用 C++ 开发底层,QtQuick 用来加载.处理图像,然后使用 Qt 提供的接口 ...

  6. 【常见踩坑】USB调试安装失败(Installation failed with message INSTALL_CANCELED_BY_USER)

    一.写在前面 最近一直在忙活着项目重构,忙活了一个多月(那是天天加班,不分昼夜呀,ps:这不是我司要求的哈),终于把沉积了三四年的老项目给重构了,目前在测试阶段,也总算有了点闲时来跟大家分享分享一些问 ...

  7. RxJava 笔记

    前言 目前 RxJava 是安卓开发圈内最流行的库之一,本来准备研究研究,但看了扔物线写的<给 Android 开发者的 RxJava 详解>后,觉得生无可恋,哦不,是觉得已经写无可写. ...

  8. spring mvc和web-flow的整合方案

    发现了一份整合spring MVC 和webflow的很好的资料,日后翻译出来发布.先记着. http://docs.spring.io/spring-webflow/docs/2.3.x/refer ...

  9. noip2008(最优贸易)

    C 国有 n 个大城市和 m 条道路,每条道路连接这 n 个城市中的某两个城市.任意两个城市之间最多只有一条道路直接相连.这 m 条道路中有一部分为单向通行的道路,一部分为双向通行的道路,双向通行的道 ...

  10. WinFrom中使用WPF的窗体

    步骤 1.添加WindowsFormsIntegration.dll .System.Windows.Forms.和System.Xaml,PresentationCore.PresentationF ...