天天看點

require.js入門簡介——和派孔明

RequireJS的常用方法

1、requireJS.config 通常來為子產品指定别名,友善子產品的引入

2、requirejs 通過它将寫好的子產品進行引入,并根據引入的子產品編寫主代碼

3、define 我們利用它來編寫子產品,然後在相應的地方進行引用

index.html

<!DOCTYPE html>
<html>
    <head>
    </head>
    <body>
<script src="js/require.js" data-main="js/main"></script> 
    </body>
</html>
           

main.js

requirejs.config({
    paths: {//為名字較長的子產品指定别名,在使用requirejs時,加載子產品時不用寫.js字尾的,當然也是不能寫字尾
        jquery: 'jquery.1.9.0.min'
    }
});
requirejs(['jquery','validate'],function($,validate){//引入子產品
    console.log(validate.isEqual(,));
});
           

validate.js

define(['jquery'],function($){
    return {//功能子產品
        isEmpty: function (){},
        checkLength: function (){},
        isEqual: function (str1,str2){
            return str1 === str2;
        }
    };
});
           

**注意:**require中的依賴是一個數組,即使隻有一個依賴,你也必須使用數組來定義,requir API的第二個參數是callback,一個function,是用來處理加載完畢後的邏輯,如:

require(["js/a"],function(){
    alert("load finished");
})
           

加載檔案

很多時候加載的JS可能來自本地伺服器、其他網站或CDN,如:

require.config({
    paths : {//在使用requirejs時,加載子產品時不用寫.js字尾的,當然也是不能寫字尾
        "jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery","js/jquery"]   
    }
})
require(["jquery","js/a"],function($){
    $(function(){
        alert("load finished");  
    })
})
           

1、require.config是用來配置子產品加載位置,簡單點說就是給子產品起一個更短更好記的名字,比如将百度的jquery庫位址标記為jquery,這樣在require時隻需要寫[“jquery”]就可以加載該js,本地的js我們也可以這樣配置;

2、通過paths的配置會使我們的子產品名字更精煉,paths還有一個重要的功能,就是可以配置多個路徑,如果遠端cdn庫沒有加載成功,可以加載本地的庫;

3、上面例子中的callback函數中發現有$參數,這個就是依賴的jquery子產品的輸出變量,如果你依賴多個子產品,可以依次寫入多個參數來使用;

require(["jquery","underscore"],function($, _){
    $(function(){
        _.each([,,],alert);
    })
})
           

如果某個子產品不輸出變量值,則沒有,是以盡量将輸出的子產品寫在前面,防止位置錯亂引發誤解

全局配置

上面的例子中重複出現了require.config配置,如果每個頁面中都加入配置,必然顯得十分不雅,requirejs提供了一種叫”主資料”的功能,我們首先建立一個main.js

require.config({
    paths : {
        "jquery" : ["http://libs.baidu.com/jquery/2.0.3/jquery", "js/jquery"],
        "a" : "js/a"   
    }
})
           

然後再頁面中使用下面的方式來使用requirejs;

1、加載requirejs腳本的script标簽加入了data-main屬性,這個屬性指定的js将在加載完reuqire.js後處理,我們把require.config的配置加入到data-main後,就可以使每一個頁面都使用這個配置,然後頁面中就可以直接使用require來加載所有的短子產品名

2、data-main還有一個重要的功能,當script标簽指定data-main屬性時,require會預設的将data-main指定的js為根路徑,是什麼意思呢?如上面的data-main=”js/main”設定後,我們在使用require([‘jquery’])後(不配置jquery的paths),require會自動加載js/jquery.js這個檔案,而不是jquery.js,相當于預設配置了

require.config({
    baseUrl : "js"
})
           

第三方子產品

通過require加載的子產品一般都需要符合AMD規範即使用define來申明子產品,但是部分時候需要加載非AMD規範的js,這時候就需要用到另一個功能:shim,shim解釋起來也比較難了解,shim直接翻譯為”墊”,其實也是有這層意思的,目前我主要用在兩個地方

1、 非AMD子產品輸出,将非标準的AMD子產品”墊”成可用的子產品,例如:在老版本的jquery中,是沒有繼承AMD規範的,是以不能直接require[“jquery”],這時候就需要shim,比如我要是用underscore類庫,但是他并沒有實作AMD規範,那我們可以這樣配置

require.config({
    shim: {
        "underscore" : {
            exports : "_";
        }
    }
})
           

這樣配置後,我們就可以在其他子產品中引用underscore子產品:

require(["underscore"], function(_){
    _.each([,,], alert);
})
           

插件形式的非AMD子產品,我們經常會用到jquery插件,而且這些插件基本都不符合AMD規範,比如jquery.form插件,這時候就需要将form插件”墊”到jquery中

require.config({
    shim: {
        "underscore" : {
            exports : "_";
        },
        "jquery.form" : {
            deps : ["jquery"]
        }
    }
})
           

也可以簡寫為

require.config({
    shim: {
        "underscore" : {
            exports : "_";
        },
        "jquery.form" : ["jquery"]
    }
})
           

這樣配置之後我們就可以使用加載插件後的jquery了

require.config(["jquery", "jquery.form"], function($){
    $(function(){
        $("#form").ajaxSubmit({...});
    })
})
           

繼續閱讀