js模塊化開發


為什么要進行模塊化開發?

1.當你寫了一個這樣的comm.js文件時,里面有function tab(){}方法,這時,你給你的同事用,你同事把這個comm.js引入頁面后,在頁面上又寫了一個function tab(){},這時,就會覆蓋你在comm.js中的tab方法。因為這個同事不知道你comm.js中有tab這個方法名。

2.如果你同事在頁面上引入了你寫的comm.js后,又引入了一個第三方插件xxx,而這個xxx插件里面剛好也有tab方法,那這時就會出現問題。你同事就會找你,說你寫的comm.js有問題。

這時,你可能會這樣寫comm.js。

var chaojidan = {};

chaojidan.tab = function(){};

這種命名空間的方式,可以降低沖突,但是無法避免沖突。

3.假如你的comm.js中現在有20個方法,但是我們的頁面現在只需要tab這個功能,也就是只需要調用tab方法。那么,這時,你可能會把comm.js分成多個js文件,比如:tab.js,comm.js,drag.js。這時,你的頁面就會出現引入多個js的情況,比如:

<script src="a.js"></script>

<script src="b.js"></script>

<script src="c.js"></script>

<script src="d.js"></script>

但是,如果這時a.js依賴於d.js的話,就會出現問題。

4.上面的依賴問題,有人說,可以把d.js放在a.js上面不就行了。但是這不能解決依賴問題,比如:當你這樣寫好一個頁面后,產品經理要你添加功能,這時你又添加了一個e.js,而e.js依賴於a.js。這時,你在新頁面添加新功能時,你必須把d.js,a.js,e.js按順序進行加載。當出現大規模的依賴時,你就會奔潰了。

模塊化的庫,sea.js(CMD),require.js(AMD)。

我們來看看sea.js如何解決js模塊化開發:

1.引入sea.js庫。

2.如何變成模塊,通過define方法。比如:

define(function(require,exports,module){

  function tab(){

    ....

  }

  exports.tab= tab;

})

這時,你在這里定義一個function tab(){},不會跟define里面的那個tab方法起沖突。

3.如何調用模塊?通過seajs.use()方法,比如:

seajs.use("./comm.js",function(ex){

  ex.tab();

})

4.如何解決模塊間的依賴問題,通過require方法。比如:

a.js

define(function(require,exports,module){

  var d = require("./d.js");     //模塊a依賴模塊d。

  function tab(){

    d.drag();

  }

  exports.tab= tab;

})

d.js

define(function(require,exports,module){

  function drag(){

    ....

  }

  exports.drag= drag;

})

上面的require方法加載模塊是同步的,而require.async()方法,加載模塊是異步的。

他們之間的區別是什么呢?舉個例子:

a.js

define(function(require,exports,module){

  var d = require("./d.js");     //模塊a依賴模塊d。

  var ele = document.getElementById("input");   //當你在頁面上調用seajs.use("./a.js")時,頁面上的input元素就綁定了click事件。但是這時d.js,b.js,以及a.js都從服務器下載到瀏覽器端了。盡管這時還不需要b.js模塊,只有點擊了input元素才需要。這時,我們只需要把require("./b.js").scale(); 改成require.async("./b.js",function(ex){ex.scale()});這時,只會下載d.js和a.js,而b.js不會下載,只有等你click元素input時,才會去下載b.js,然后執行b.js,執行結束后,就會調用回調函數,這時,就調用ex.scale()方法了。這叫做按需載入。

  ele.onclick = function(){

    require("./b.js").scale();       

  }

})

b.js

define(function(require,exports,module){  

  function scale(){

    ....

  }

  exports.scale= scale;

})

js模塊化的發展:

node.js是最早使用模塊化進行開發的,遵循的規范是:CommonJS,這是服務端的模塊化規范,服務器使用此規范進行開發,是因為它所需要的文件就在服務器本地。而瀏覽器端需要的文件在服務器端,不在瀏覽器本地,因此就出現了AMD規范。

require.js遵守AMD規范,在瀏覽器端進行模塊化開發的庫。

sea.js遵守CMD規范,在瀏覽器端進行模塊化開發的庫。

我們開發網頁一般要遵守這種開發模式就行了:

1.底層庫jQuery

2.組件開發,可以基於jQuery

3.業務應用開發,基於jQuery和組件

通過sea.js等模塊化庫,把上面所有的模塊連起來。

模塊化在前端開發中還是很重要的,ECMAScript第六版將正式支持模塊化語法,也就是說不用利用模塊化庫,就能實現模塊化的功能。

 

 

 

加油!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM