天天看點

JS子產品化工具requirejs教程(二):基本知識

require會定義三個變量:define,require,requirejs,其中require === requirejs,一般使用require更簡短

define 從名字就可以看出這個api是用來定義一個子產品

require 加載依賴子產品,并執行加載完後的回調函數

前一篇中的a.js:

通過define函數定義了一個子產品,然後再頁面中使用:

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

之前的例子中加載子產品都是本地js,但是大部分情況下網頁需要加載的JS可能來自本地伺服器、其他網站或CDN,這樣就不能通過這種方式來加載了,我們以加載一個jquery庫為例:

這邊涉及了​<code>​require.config​</code>​,​<code>​require.config​</code>​是用來配置子產品加載位置,簡單點說就是給子產品起一個更短更好記的名字,比如将百度的jquery庫位址标記為​<code>​jquery​</code>​,這樣在require時隻需要寫​<code>​["jquery"]​</code>​就可以加載該js,本地的js我們也可以這樣配置:

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

這樣配置後,當百度的jquery沒有加載成功後,會加載本地js目錄下的jquery

在使用requirejs時,加載子產品時不用寫​<code>​.js​</code>​字尾的,當然也是不能寫字尾

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

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

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

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

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

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

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

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

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

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

也可以簡寫為:

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

好了,requirejs的基本配置大緻就是這麼多,還有一些擴充的功能會在之後的篇幅中提到

繼續閱讀