<ruby id="h6500"><table id="h6500"></table></ruby>
    1. <ruby id="h6500"><video id="h6500"></video></ruby>
          1. <progress id="h6500"><u id="h6500"><form id="h6500"></form></u></progress>

            Javascript模塊化編程(一):模塊的寫(xiě)法

            發(fā)表于:2013-09-03來(lái)源:阮一峰的網(wǎng)絡(luò )日志作者:阮一峰點(diǎn)擊數: 標簽:JavaScript
            隨著(zhù)網(wǎng)站逐漸變成"互聯(lián)網(wǎng)應用程序",嵌入網(wǎng)頁(yè)的Javascript代碼越來(lái)越龐大,越來(lái)越復雜。

              隨著(zhù)網(wǎng)站逐漸變成"互聯(lián)網(wǎng)應用程序",嵌入網(wǎng)頁(yè)的Javascript代碼越來(lái)越龐大,越來(lái)越復雜。

              網(wǎng)頁(yè)越來(lái)越像桌面程序,需要一個(gè)團隊分工協(xié)作、進(jìn)度管理、單元測試等等......開(kāi)發(fā)者不得不使用軟件工程的方法,管理網(wǎng)頁(yè)的業(yè)務(wù)邏輯。

              Javascript模塊化編程,已經(jīng)成為一個(gè)迫切的需求。理想情況下,開(kāi)發(fā)者只需要實(shí)現核心的業(yè)務(wù)邏輯,其他都可以加載別人已經(jīng)寫(xiě)好的模塊。

              但是,Javascript不是一種模塊化編程語(yǔ)言,它不支持"類(lèi)"(class),更遑論"模塊"(module)了。(正在制定中的ECMAScript標準第六版,將正式支持"類(lèi)"和"模塊",但還需要很長(cháng)時(shí)間才能投入實(shí)用。)

              Javascript社區做了很多努力,在現有的運行環(huán)境中,實(shí)現"模塊"的效果。本文總結了當前"Javascript模塊化編程"的最佳實(shí)踐,說(shuō)明如何投入實(shí)用。雖然這不是初級教程,但是只要稍稍了解Javascript的基本語(yǔ)法,就能看懂。

              一、原始寫(xiě)法

              模塊就是實(shí)現特定功能的一組方法。

              只要把不同的函數(以及記錄狀態(tài)的變量)簡(jiǎn)單地放在一起,就算是一個(gè)模塊。

              function m1(){

              //...

              }

              function m2(){

              //...

              }

              上面的函數m1()和m2(),組成一個(gè)模塊。使用的時(shí)候,直接調用就行了。

              這種做法的缺點(diǎn)很明顯:"污染"了全局變量,無(wú)法保證不與其他模塊發(fā)生變量名沖突,而且模塊成員之間看不出直接關(guān)系。

              二、對象寫(xiě)法

              為了解決上面的缺點(diǎn),可以把模塊寫(xiě)成一個(gè)對象,所有的模塊成員都放到這個(gè)對象里面。

              var module1 = new Object({

              _count : 0,

              m1 : function (){

              //...

              },

              m2 : function (){

              //...

              }

              });

              上面的函數m1()和m2(),都封裝在module1對象里。使用的時(shí)候,就是調用這個(gè)對象的屬性。

              module1.m1();

              但是,這樣的寫(xiě)法會(huì )暴露所有模塊成員,內部狀態(tài)可以被外部改寫(xiě)。比如,外部代碼可以直接改變內部計數器的值。

              module1._count = 5;

              三、立即執行函數寫(xiě)法

              使用"立即執行函數"(Immediately-Invoked Function Expression,IIFE),可以達到不暴露私有成員的目的。

              var module1 = (function(){

              var _count = 0;

              var m1 = function(){

              //...

              };

              var m2 = function(){

              //...

              };

              return {

              m1 : m1,

              m2 : m2

              };

              })();

              使用上面的寫(xiě)法,外部代碼無(wú)法讀取內部的_count變量。

              console.info(module1._count); //undefined

              module1就是Javascript模塊的基本寫(xiě)法。下面,再對這種寫(xiě)法進(jìn)行加工。

              四、放大模式

              如果一個(gè)模塊很大,必須分成幾個(gè)部分,或者一個(gè)模塊需要繼承另一個(gè)模塊,這時(shí)就有必要采用"放大模式"(augmentation)。

              var module1 = (function (mod){

              mod.m3 = function () {

              //...

              };

              return mod;

              })(module1);

              上面的代碼為module1模塊添加了一個(gè)新方法m3(),然后返回新的module1模塊。

              五、寬放大模式(Loose augmentation)

              在瀏覽器環(huán)境中,模塊的各個(gè)部分通常都是從網(wǎng)上獲取的,有時(shí)無(wú)法知道哪個(gè)部分會(huì )先加載。如果采用上一節的寫(xiě)法,第一個(gè)執行的部分有可能加載一個(gè)不存在空對象,這時(shí)就要采用"寬放大模式"。

              var module1 = ( function (mod){

              //...

              return mod;

              })(window.module1 || {});

              與"放大模式"相比,"寬放大模式"就是"立即執行函數"的參數可以是空對象。

              六、輸入全局變量

              獨立性是模塊的重要特點(diǎn),模塊內部最好不與程序的其他部分直接交互。

              為了在模塊內部調用全局變量,必須顯式地將其他變量輸入模塊。

              var module1 = (function ($, YAHOO) {

              //...

              })(jQuery, YAHOO);

              上面的module1模塊需要使用jQuery庫和YUI庫,就把這兩個(gè)庫(其實(shí)是兩個(gè)模塊)當作參數輸入module1。這樣做除了保證模塊的獨立性,還使得模塊之間的依賴(lài)關(guān)系變得明顯。這方面更多的討論,參見(jiàn)Ben Cherry的著(zhù)名文章《JavaScript Module Pattern: In-Depth》。

              這個(gè)系列的第二部分,將討論如何在瀏覽器環(huán)境組織不同的模塊、管理模塊之間的依賴(lài)性。

            原文轉自:http://www.ruanyifeng.com/blog/2012/10/javascript_module.html

            老湿亚洲永久精品ww47香蕉图片_日韩欧美中文字幕北美法律_国产AV永久无码天堂影院_久久婷婷综合色丁香五月
              <ruby id="h6500"><table id="h6500"></table></ruby>
              1. <ruby id="h6500"><video id="h6500"></video></ruby>
                    1. <progress id="h6500"><u id="h6500"><form id="h6500"></form></u></progress>