随着JS越来越庞大,已经不仅仅是以前复制粘贴做特效的时代了,JS越来越偏向于业务逻辑与应用。JS在web开发中占有越来越重要的地位。

由于JS代码庞大,文件数目多,传统的使用<script src=""></script>会带来很多性能的问题,因此requirejs可以为我们提供解决思路,它有以下的功能:

1、声明不同js文件之间的依赖

2、可以按需、并行、延时载入js库

3、可以让我们的代码以模块化的方式组织

下面进行实战:

文档结构是这样的

.js/app/config.js

.js/require.js

.js/app/hello1.js

.js/app/hello2.js

.js/app/hello3.js

index.html

在index.html中引入requirejs

<script src="js/require.js" data-main="js/app/config.js"></script>

其中,data-main指定主要的配置文件. config.js如下:

require.config({

   //默认情况下模块所在目录为js/app
baseUrl: 'js/app', //这里设置的路径是相对与baseUrl的,不要包含.js,否则会报错
paths: { h1: 'hello1',
       h2:'hello2',
       h3:'hello3'
} }); // 开始逻辑.
requirejs(['h1', 'h2', 'h3'], function (h1, h2, h3) {
//这里是引入那三个js之后的回调函数
    h1.hello(); //I am hello1
    h2.hello(); //I am hello2
    h3.hello(); //I am hello3 });

  

hello1.js

define([], function() {
return {
hello: function() {
console.log("I am hello1");
}
}
});

hello2.js

define([], function() {
return {
hello: function() {
console.log("I am hello2");
}
}
});

hello3.js

define([], function() {
return {
hello: function() {
console.log("I am hello3");
}
}
});

 

require加载文件时,会自动加上.js后缀。当某些模块依赖其他模块时,可以通过define([xxx],function(xxx){yyy});的方式添加依赖关系,

require会在异步加载后,自动调整次序。

shim

当有些js不是AMD规范的时候,或者我有一个public.js需要依赖于jquery时,config.js可以这样写

代码如下:

requirejs.config({

	baseUrl: 'js/app',
  
paths:{
"jquery":"jquery-1.11.2.min",
"public":"public",
}, // 这个配置是你在引入依赖的时候的包名,比如一些不是AMD规范的插件
shim: {
'public': {
deps: ['jquery'],
       //exporets 就是被外界访问的接口,比如jquery的$ 
exports: 'public'
},
}
}); require(['public'], function (p) { // somecode
});

  

使用中遇到的问题以及解决方法:

当我require.js没有用在单页面的时候,我遇到了这样一个问题:

  比如我1.html需要有另外的一些单独函数,而其他页面是不需要的,并且我希望在加载完config.js之后再执行我那个单独的函数,那要怎么做呢。

如果直接写在config.js里面的require后的回调函数那里,那么要单独分开每一个config.js,这样就没意思了。一位博友给出的答案是

index.html

<script src="js/require.js" data-main="js/app/config.js"  require-module="js/app/other.js"></script> //加个require-module属性,后面加上你需要单独引入的js

  

config.js 里面这样

require.config({

	baseUrl: 'js/app',
paths:{
"jquery":"jquery-1.11.2.min",
"public":"public",
}, shim: {
'public': {deps: ['jquery'],exports:'public'}
} }); require(['jquery','public'], function($,p){
    //改变的是这里
var scripts = document.getElementsByTagName("script");
for (var i = 0; i < scripts.length; i++) {
    // 获取页面所需加载模块入口名称,需要单独引入的js写在 script里面 require-module这个属性这里
var module = scripts[i].getAttribute("require-module");
if (module != undefined && module != "") {
require([module ]);
break;
}
} });

  

这样的话,你就可以在确保config里面的js加载完毕后,再加载你自己的js

暂时先写到这里先,有错误的话欢迎指出

【原】requirejs学习笔记的更多相关文章

  1. RequireJS学习笔记

    前言 进入移动前端是很不错的选择,这块也是我希望的道路,但是不熟悉啊... 现在项目用的是require+backbone,整个框架被封装了一次,今天看了代码搞不清楚,觉得应该先从源头抓起,所以再看看 ...

  2. Requirejs学习笔记(一)

    中文api 和 英文api网上都有的我就不翻译了,我的学习方法是先看英文api,然后看不懂的就比对中文api看一遍. requirejs可以帮助js代码模块化开发,模块化意味了解决了代码凌乱的问题,方 ...

  3. RequireJS学习笔记(转)

    前言 进入移动前端是很不错的选择,这块也是我希望的道路,但是不熟悉啊... 现在项目用的是require+backbone,整个框架被封装了一次,今天看了代码搞不清楚,觉得应该先从源头抓起,所以再看看 ...

  4. RequireJs学习笔记之data-main Entry Point

    You will typically use a data-main script to set configuration options and then load the first appli ...

  5. RequireJs学习笔记之Define a Module

    简单的键值对定义define({    color: "black",    size: "unisize"}); 如果一个模块没有任何依赖,又需要做用一个函数 ...

  6. Matplotlib学习笔记(二)

    原  Matplotlib学习笔记 参考:Python数据科学入门教程 Python3.6.1 jupyter notebook .caret, .dropup > .btn > .car ...

  7. Matplotlib学习笔记(一)

    原   matplotlib学习笔记 参考:Python数据科学入门教程 Python3.6.1 jupyter notebook .caret, .dropup > .btn > .ca ...

  8. 【原】Learning Spark (Python版) 学习笔记(三)----工作原理、调优与Spark SQL

    周末的任务是更新Learning Spark系列第三篇,以为自己写不完了,但为了改正拖延症,还是得完成给自己定的任务啊 = =.这三章主要讲Spark的运行过程(本地+集群),性能调优以及Spark ...

  9. 并发编程学习笔记(4)----jdk5中提供的原子类及Lock使用及原理

    (1)jdk中原子类的使用: jdk5中提供了很多原子类,它会使变量的操作变成原子性的. 原子性:原子性指的是一个操作是不可中断的,即使是在多个线程一起操作的情况下,一个操作一旦开始,就不会被其他线程 ...

随机推荐

  1. Mybatis学习--spring和Mybatis整合

    简介 在前面写测试代码的时候,不管是基于原始dao还是Mapper接口开发都有许多的重复代码,将spring和mybatis整合可以减少这个重复代码,通过spring的模板方法模式,将这些重复的代码进 ...

  2. Oracle 死锁的检测查询及处理

    来源于: http://www.cnblogs.com/hoojo/archive/2012/08/31/2665583.html -- 死锁查询语句 SELECT bs.username " ...

  3. [转]java.lang.OutOfMemoryError: PermGen space及其解决方法

    原文地址:http://peak.iteye.com/blog/52606 这个问题是我的工程中加入了Birt报表在Linux环境下运行出现的问题,从网上搜索了一下看到这文章发现并不是由于Birt的原 ...

  4. npm安装完bower,使用时提示bower不是内部或外部命令

    归根结底还是环境变量的问题,但是配了好几次没配成功,最后就直接把装好的node里面的复制到系统创建的环境变量目录下,问题解决! 问题描述:我们安装node.js,npm,通过npm安装bower一路正 ...

  5. 51nod 1101换零钱(背包)

    N元钱换为零钱,有多少不同的换法?币值包括1 2 5分,1 2 5角,1 2 5 10 20 50 100元.   例如:5分钱换为零钱,有以下4种换法: 1.5个1分 2.1个2分3个1分 3.2个 ...

  6. 资源: StaticResource, ThemeResource

    StaticResource ThemeResource 示例1.演示“StaticResource”相关知识点Resource/StaticResourceDemo.xaml <Page x: ...

  7. HTML5前端(移动端网站)性能优化指南

    HTML5是一种最新发布网页构架的普遍模型,是构建对程序.对用户都更有价值的数据驱动的Web的前端技术框架,它的价值在于融合CSS/javaScript/flash等众多前端开发技术,更多的体现在对交 ...

  8. SQL server 中的@,@@、#,##分别代表什么?

    @声明变量,@@系统函数,#本地临时表,##全局临时 表    

  9. Python字符串基础一

    下一篇:Python 序列通用操作介绍 写在前面 下学期开始上计算机网络的课程,现在已经在看相关书籍,希望结合python写出一个网络爬虫程序.利用学习C++后的空余时间来看看Python并在这里总结 ...

  10. oracle 11g 新特性UTL_TCP、UTL_HTTP 和 UTL_SMTP程序包发邮件

    首先,创建一个 ACL: begindbms_network_acl_admin.create_acl (acl             => 'utlpkg.xml', ---创建的访问控制列 ...