【原】requirejs学习笔记

  随着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

 

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

 

posted @ 2016-03-09 11:37  咸鱼老弟  阅读(468)  评论(0编辑  收藏  举报