requireJS-3调用非 AMD 规范 js

1.AMD规范

(1)define 定义模块

(一)define 定义独立模块

如果被定义的模块是一个独立模块,不需要依赖任何其他模块,可以直接用define方法生成。

define({ method1: function() {}, method2: function() {}, });

上面代码生成了一个拥有method1、method2两个方法的模块。
另一种等价的写法是,把对象写成一个函数,该函数的返回值就是输出的模块。

define(function () { 
return { 
method1: function() {},
 method2: function() {}, 
}; 
});
(二)非独立模块

如果被定义的模块需要依赖其他模块,则define方法必须采用下面的格式。

define(['module1', 'module2'], function(m1, m2) { ... });

以上参考 RequireJS和AMD规范

2.requireJS config 方法

**(1)paths **
paths参数指定各个模块的位置。这个位置可以是同一个服务器上的相对位置,也可以是外部网址。可以为每个模块定义多个位置,如果第一个位置加载失败,则加载第二个位置,上面的示例就表示如果CDN加载失败,则加载服务器上的备用脚本。需要注意的是,指定本地文件路径时,可以省略文件最后的js后缀名。

**(2)baseUrl **
baseUrl参数指定本地模块位置的基准目录,即本地模块的路径是相对于哪个目录的。该属性通常由require.js加载时的data-main属性指定。
(3)shim
有些库不是AMD兼容的,这时就需要指定shim属性的值。shim可以理解成“垫片”,用来帮助require.js加载非AMD规范的库。

3.shim 加载非AMD模块

(1)形式1

** b.js**

var hello = function () {//     
console.log('hello 1');// 
};

hello 为b1.js 暴露的全局变量
main.js

require.config({    
baseUrl:'js/',    
shim:{        
'b':{            
exports:'hello',    //hello 与b中暴露的全局变量一致        
deps:['math']        
     }    
},    
paths:{        
"a":"a",        
'jquery':'jquery-3.1.0.min',       
 'math':'math'    
},
})
require(['jquery',"a"],function ($) {   
 $(function () {        alert('load finished');   
 })
});

a.js 依赖于b1.js(即a.js 中调用b.js 的函数)
a.js

define(['b'], function(b){    
       function fun1(){ 
       b();      
       console.log(b);    
};    
fun1(); 
});

输出结果
浏览控制台输出:

1
 function () {//     
console.log('hello 1');// 
}

(2)形式2

b.js

var Bobj = (function () {  
  var name = 'scarlet';    
  var hello = function () {       
     console.log('hello '+name);    
  }    
  return{        
    hello:hello    
  }
})();

main.js

require.config({
    baseUrl:'js/',
    shim:{
        'b':{
            exports:'Bobj',//Bobj 于b.js 暴露的全局变量名一致
            deps:['math']
        }    },
    paths:{
        "a":"a",
        'jquery':'jquery-3.1.0.min', 
       'math':'math'    },})
require(['jquery',"a"],function ($) {
    $(function () {
        alert('load finished');
    })});

a.js

define(['b'],
    function(b){
    function fun1(){
       b.hello();        //b;
       console.log(b);
    };
    fun1(); 
})

控制台输出

....
hello scarlet
Object

(3)形式3

b.js

var hello3 = function () {
    console.log('hello 3');
}();

main.js

require.config({
    baseUrl:'js/',
    shim:{
        'b':{
            exports:'hello3', 
           deps:['math']
        }
    },
    paths:{
        "a":"a", 
       'jquery':'jquery-3.1.0.min',
        'math':'math'
    },})
require(['jquery',"a"],function ($) {
    $(function () {
        alert('load finished');
    })});

a.js
define(['b'], function(b){
function fun1(){
b;
console.log(b);
};
fun1();
})
控制台输出
hello 3
undefined

总结

exports :是指引用的js文件暴露的全局变量。也是外部js引用是使用的变量(可能是函数,也可能是对象)。

4.依赖(例如 b.js 依赖 math.js )

b.js 是非AMD规范的js ,math.js 是自定义的AMD规范的js。b.js 依赖于math.js (b.js 的hello 函数调用 math.js 的rev函数)
b.js

var Bobj = (function () {
   var name = 'scarlet';
   var hello = function (math) {
       console.log("b.js ___________start");
       console.log('hello '+name);
       console.log(math.rev(name+' hello'));
       console.log("b.js ____________finshed");
   }
   return{
       hello:hello
   }
})();

math.js

define(function () {
    var add = function (a,b) {
        return a+b;
    } 
   var sub = function (a,b) {
      return a-b;
    };
    var rev= function (str) {
        var revS = "";
        for(var i = str.length-1;i >=0;i--){
            revS +=str[i];
        }
        return revS;
    };
    return {
        add:add,
        sub:sub,
        rev:rev
    };
})

main.js

/** * Created by lxy_920912 on 16/9/8. */
require.config({
    baseUrl:'js/',
    shim:{
        'b':{
            exports:'Bobj',
            deps:['math']
        }
    },
    paths:{
        "a":"a",
        'c':'c',
        'jquery':'jquery-3.1.0.min',
        'math':'math'
    },
})
require(['jquery',"a",'c','math','b'],function ($,a,c,math,b) {
    $(function () {
        a.fun1();
        c.fun1(); 
       a.fun3(c); 
       alert('load finished'); 
       b.hello(math) 
   })
});

5循环依赖

a.js 依赖于c.js ,c.js 依赖于 a.js.
(a.js 的fun3 调用c.js 的fun1,c.js 的fun1 调用a.js 的fun1)
a.js

define(['jquery','math','text!input.txt','b','require','c'],    function($,math,input,b,c){
    var fun1 = function (){
        console.log('_______________a fun1__________________________');
        console.log("add: "+math.add("hello "," scarlet")+"\n sub: "+math.sub(5,23));
        console.log(math.rev('ABCDEFG'));
        b.hello();
        console.log('_______________a fun1 finished__________________________');    };
  var fun2 = function fun2(input) {        
      var ptext =document.createTextNode(input) ;
     document.body.appendChild(ptext);
        //require('c').fun1();
        console.log('a fun2 finished');    };
    var fun3 = function (c) {
        console.log('a fun3______________')
        //var c = require('c');
        c.fun1();
        console.log('a fun3 finished_______');
    }    
fun2(input);
        return {
            fun1:fun1,
            fun2:fun2,
            fun3:fun3
        }
})

c.js

define(['require','a'],function (require,a) {
    var fun1 = function fun1() {
        require("a").fun1();
        console.log('c fun1 finished');
    }
    return {
        fun1:fun1
    }
})

main.js

require.config({
    baseUrl:'js/',
    shim:{
        'b':{
            exports:'Bobj',
            deps:['math'] 
       }    },
    paths:{
        "a":"a",
        'c':'c', 
       'jquery':'jquery-3.1.0.min',
        'math':'math' 
   },})
require(['jquery',"a",'c','math','b'],function ($,a,c,b) {
    $(function () {
        a.fun1();
       c.fun1(); 
       a.fun3(c);
       alert('load finished');
    })
});

如果你定义一个循环依赖关系 (a 依赖c 并且 c 依赖 a),那么当c的模块构造函数被调用的时候,传递给他的a会是undefined。 但是c可以在a模块在被引入之后通过require(‘a’)来获取a (一定要把require作为依赖模块,RequireJS才会使用正确的 context 去查找 a):

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,245评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,749评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,960评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,575评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,668评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,670评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,664评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,422评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,864评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,178评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,340评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,015评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,646评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,265评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,494评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,261评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,206评论 2 352

推荐阅读更多精彩内容