前端模塊化開發解決方案詳解

1、模塊化開發方案

前端發展到今天,已經有很多模塊化的方案,好比前端

CommonJS(經常使用在服務器端,同步的,如nodejs)node

AMD(經常使用在瀏覽器端,異步的,如requirejs)(Asynchronous Module Definition)程序員

CMD(經常使用在瀏覽器端,異步的,如seajs編程

UMD(AMD&& CommonJS) 這些模塊化規範的核心價值都是讓 JavaScript 的模塊化開發變得簡單和天然。數組

 

服務器端模塊 在服務器端,全部的模塊都存放在本地硬盤,能夠同步加載完成,等待時間就是硬盤的讀取時間。瀏覽器

瀏覽器端模塊: 在瀏覽器端,全部的模塊都放在服務器端,同步加載,等待時間取決於網速的快慢,可能要等很長時間,瀏覽器處於"假死"狀態。所以,瀏覽器端的模塊,不能採用"同步加載"(synchronous),只能採用"異步加載"(asynchronous)。緩存

2、CommonJs 

CommonJs 是服務器端模塊的規範,Node.js採用了這個規範。 CommonJS 加載模塊是同步的,因此只有加載完成才能執行後面的操做。 像Node.js主要用於服務器的編程,加載的模塊文件通常都已經存在本地硬盤,因此加載起來比較快,不用考慮異步加載的方式,因此CommonJS規範比較適用。 服務器

CommonJS模塊的特色以下: 全部代碼都運行在模塊做用域,不會污染全局做用域。 模塊能夠屢次加載,可是隻會在第一次加載時運行一次,而後運行結果就被緩存了,之後再加載,就直接讀取緩存結果。 模塊加載的順序,按照其在代碼中出現的順序。異步

CommonJS語法async

一、定義模塊 

根據CommonJS規範,每一個文件就是一個模塊,有本身的做用域。在一個文件裏面定義的變量、函數、都是私有的,對其餘文件不可見。若是想在多個文件分享變量,必須定義爲頂層對象的屬性,如:global.warning = true;上面代碼的warning變量,能夠被全部文件讀取。固然,這樣寫法是不推薦的。

二、模塊的接口

CommonJS規範規定,每一個模塊內部,module變量表明當前模塊。這個變量是一個對象,它的exports屬性(即module.exports)是對外的接口。加載某個模塊,實際上是加載該模塊的module.exports屬性。

三、加載模塊

加載模塊使用require方法,該方法讀取一個文件並執行,返回文件內部module.exports對象 注:不一樣的實現對require時的路徑有不一樣要求,通常狀況能夠省略js拓展名,可使用相對路徑,也可使用絕對路徑,甚至能夠省略路徑直接使用模塊名(前提是該模塊是系統內置模塊)

 3、AMD

AMD是"Asynchronous Module Definition"的縮寫,意思就是"異步模塊定義". RequireJS是一個工具庫,主要用於客戶端的模塊管理。它可讓客戶端的代碼分紅一個個模塊,實現異步或動態加載,從而提升代碼的性能和可維護性。它的模塊管理遵照AMD規範。 RequireJS的基本思想是,經過define方法,將代碼定義爲模塊;經過require方法,實現代碼的模塊加載。 首先,將require.js嵌入網頁,而後就能在網頁中進行模塊化編程了。 <script data-main="scripts/main" src="scripts/require.js"></script> 上面代碼的data-main屬性可省略,用於指定主代碼所在的腳本文件,在上例中爲scripts子目錄下的main.js文件。用戶自定義的代碼就放在這個main.js文件中。

AMD語法

一、定義模塊

define(id?, dependencies?, factory);

id:可選參數,用來定義模塊的標識,若是沒有提供該參數,腳本文件名(去掉拓展名)

dependencies:是一個數組,表示當前模塊的依賴

factory:工廠方法,模塊初始化要執行的函數或對象。若是爲函數,它應該只被執行一次。若是是對象,此對象應該爲模塊的輸出值 

二、加載模塊

require([dependencies], function(){});  第一個參數是一個數組,表示所依賴的模塊,第二個參數是一個回調函數,當前面指定的模塊都加載成功後,它將被調用。加載的模塊會以參數形式傳入該函數,從而在回調函數內部就可使用這些模塊

 

4、CMD

CMD 即Common Module Definition通用模塊定義 CMD規範是國內發展出來的,CMD有個瀏覽器的實現SeaJS 在 CMD 規範中,一個模塊就是一個文件。

Sea.js 是一個成熟的開源項目,核心目標是給前端開發提供簡單、極致的模塊化開發體驗。這裏很少作介紹,有興趣的能夠查看官方文檔。 使用 Sea.js,在書寫文件時,須要遵照 CMD (Common Module Definition)模塊定義規範。一個文件就是一個模塊。 首先要在頁面中引入 sea.js 文件,這通常經過頁頭全局把控,也方便更新維護。想在頁面中使用某個組件時,只要經過 seajs.use 方法調用。

CMD語法

一、定義模塊 define(id?, deps?, factory) 

字符串id爲模塊標識,數組deps爲模塊依賴; 參數 factory  能夠是一個函數,也能夠爲對象或者字符串。 

factory是一個函數,有三個參數: require 是一個方法,接受 模塊標識 做爲惟一參數,用來獲取其餘模塊提供的接口:require(id) exports 是一個對象,用來向外提供模塊接口 module 是一個對象,上面存儲了與當前模塊相關聯的一些屬性和方法 注: 帶 id 和 deps 參數的 define 用法不屬於 CMD 規範,而屬於 Modules/Transport 規範。

Sea.js 帶來的兩大好處: 經過 exports 暴露接口。這意味着不須要命名空間了,更不須要全局變量。這是一種完全的命名衝突解決方案。 經過 require 引入依賴。這可讓依賴內置,開發者只需關心當前模塊的依賴,其餘事情 Sea.js 都會自動處理好。對模塊開發者來講,這是一種很好的 關注度分離,能讓程序員更多地享受編碼的樂趣。

5、AMD與CMD的區別

1.AMD推崇依賴前置。 在定義模塊的時候就要聲明其依賴的模塊; CMD推崇依賴就近,只有在用到某個模塊的時候再去require ;

2.AMD依賴模塊的執行順序和書寫順序不必定一致;CMD模塊的執行順序和書寫順序是徹底一致的

3.對於依賴的模塊AMD是提早執行,CMD是延遲執行。不過RequireJS從2.0開始,也改爲能夠延遲執行(根據寫法不一樣,處理方式不經過)。 

6、UMD: 通用模塊規範

UMD (Universal Module Definition)通用模塊規範 是AMD和CommonJS二者的結合 這個模式中加入了當前存在哪一種規範的判斷,因此可以「通用」,它兼容了AMDCommonJS,同時還支持老式的「全局」變量規範: 應用UMD規範的js文件其實就是一個當即執行函數。在執行UMD規範時,會優先判斷是當前環境是否支持AMD環境,而後再檢驗是否支持CommonJS環境,不然認爲當前環境爲瀏覽器環境( window )。固然具體的判斷順序實際上是能夠調換的。

6、前端模塊化的優缺點

一、更好的分離

若是要加載多個就得放置多個 script 標籤,若是是加載模塊的話,對於 HTML 和 JavaScript 分離頗有好處,在某些場景下這個分離度很重要。

二、更好的代碼組織方式 若是單個文件愈來愈大,維護起來出問題的概率也會愈來愈大,若是是多人開發,不一樣的代碼風格,超多的業務邏輯混雜在一塊兒,不要說維護了,光想一想感受都很麻煩。模塊式的開發,一個文件就是一個模塊,控制了文件的粒度,每一個模塊能夠專一於一個功能。

三、按需加載

四、避免命名衝突

五、更好的依賴處理

相關文章
相關標籤/搜索