JavaScript的Module模式編程是什么

本篇文章給大家分享的是有關(guān)JavaScript的Module模式編程是什么,小編覺得挺實(shí)用的,因此分享給大家學(xué)習(xí),希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。

10年積累的成都網(wǎng)站制作、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)制作后付款的網(wǎng)站建設(shè)流程,更有臨川免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

                                                           

基礎(chǔ)知識(shí)

首先我們要大概了解一下Module模式(2007年由YUI的EricMiraglia在博客中提出),如果你已熟悉 Module 模式,可以跳過本部分,直接閱讀"高級(jí)模式"。

匿名函數(shù)閉包

匿名函數(shù)閉包是JavaScript最棒的特征,沒有之一,是它讓一切都成為了可能?,F(xiàn)在我們來創(chuàng)建一個(gè)匿名函數(shù)然后立即執(zhí)行。函數(shù)中所有的代碼都是在一個(gè)閉包中執(zhí)行的,閉包決定了在整個(gè)執(zhí)行過程中這些代碼的私有性和狀態(tài)。

代碼如下:

(function () {
 // ... all vars and functions are in this scope only
 // still maintains access to all globals
}());

注意在匿名函數(shù)外面的括號(hào)。這是由于在JavaScript中以function開頭的語句通常被認(rèn)為是函數(shù)聲明。加上了外面的括號(hào)之后則創(chuàng)建的是函數(shù)表達(dá)式。

全局導(dǎo)入

JavaScript有一個(gè)特征叫做隱藏的全局變量。當(dāng)一個(gè)變量名被使用,編譯器會(huì)向上級(jí)查詢用var來聲明這個(gè)變量的語句。如果沒有找到的話這個(gè)變量就被認(rèn)為是全局的。如果在賦值的時(shí)候這樣使用,就會(huì)創(chuàng)建一個(gè)全局的作用域。這意味著在一個(gè)匿名的閉包中創(chuàng)建一個(gè)全局變量是十分容易的。不幸的是 ,這將會(huì)導(dǎo)致代碼的難以管理,因?yàn)閷?duì)于程序員來說,如果全局的變量不是在一個(gè)文件中聲明會(huì)很不清晰。幸運(yùn)的是 ,匿名函數(shù)給我我們另一個(gè)選擇。我們可以將全局變量通過匿名函數(shù)的參數(shù)來導(dǎo)入到我們的代碼中,這樣更加的快速和整潔。

代碼如下:

(function ($, YAHOO) {
// now have access to globals jQuery (as $) and YAHOO in this code
}(jQuery, YAHOO));

Module導(dǎo)出

有時(shí)你并不想要使用全局變量,但是你想要聲明他們。我們可以很容易通過匿名函數(shù)的返回值來導(dǎo)出他們。關(guān)于Module模式的基本內(nèi)容就這么多,這里有一個(gè)復(fù)雜一點(diǎn)的例子。

代碼如下:

var MODULE = (function () {
 var my = {},
  privateVariable = 1;
 function privateMethod() {
  // ...
 }
 my.moduleProperty = 1;
 my.moduleMethod = function () {
  // ...
 };
 return my;
}());

這里我們聲明了一個(gè)全局的module叫做MODULE,有兩個(gè)公有屬性:一個(gè)叫做MODULE.moduleMethod的方法和一個(gè)叫做MODULE.moduleProperty的變量。另外他通過匿名函數(shù)的閉包來維持私有的內(nèi)部狀態(tài),當(dāng)然我們也可使用前面提到的模式,輕松導(dǎo)入所需的全局變量

高級(jí)模式

之前提到的內(nèi)容已經(jīng)可以滿足很多需求了,但我們可以更深入地研究這種模式來創(chuàng)造一些強(qiáng)力的可拓展的結(jié)構(gòu)。讓我們一點(diǎn)一點(diǎn),繼續(xù)通過這個(gè)叫做MODULE的module來學(xué)習(xí)。

拓展

目前,module模式的一個(gè)局限性就是整個(gè)module必須是寫在一個(gè)文件里面的。每個(gè)進(jìn)行過大規(guī)模代碼開發(fā)的人都知道將一個(gè)文件分離成多個(gè)文件的重要性。幸運(yùn)的是我們有一個(gè)很好的方式來拓展modules。首先我們導(dǎo)入一個(gè)module,然后加屬性,最后將它導(dǎo)出。這里的這個(gè)例子,就是用上面所說的方法來拓展MODULE。

代碼如下:

var MODULE = (function (my) {
 my.anotherMethod = function () {
  // added method...
 };
 return my;
}(MODULE));

雖然不必要,但是為了一致性 ,我們?cè)俅问褂胿ar關(guān)鍵字。然后代碼執(zhí)行,module會(huì)增加一個(gè)叫做MODULE.anotherMethod的公有方法。這個(gè)拓展文件同樣也維持著它私有的內(nèi)部狀態(tài)和導(dǎo)入。

松拓展

我們上面的那個(gè)例子需要我們先創(chuàng)建module,然后在對(duì)module進(jìn)行拓展,這并不是必須的。異步加載腳本是提升 Javascript 應(yīng)用性能的最佳方式之一。。通過松拓展,我們創(chuàng)建靈活的,可以以任意順序加載的,分成多個(gè)文件的module。每個(gè)文件的結(jié)構(gòu)大致如下

代碼如下:

var MODULE = (function (my) {
 // add capabilities...
 return my;
}(MODULE || {}));

在這種模式下,var語句是必須。如果導(dǎo)入的module并不存在就會(huì)被創(chuàng)建。這意味著你可以用類似于LABjs的工具來并行加載這些module的文件。

緊拓展

雖然松拓展已經(jīng)很棒了,但是它也給你的module增添了一些局限。最重要的一點(diǎn)是,你沒有辦法安全的重寫module的屬性,在初始化的時(shí)候你也不能使用其他文件中的module屬性(但是你可以在初始化之后運(yùn)行中使用)。緊拓展包含了一定的載入順序,但是支持重寫,下面是一個(gè)例子(拓展了我們最初的MODULE)。

代碼如下:

var MODULE = (function (my) {
 var old_moduleMethod = my.moduleMethod;
 my.moduleMethod = function () {
  // method override, has access to old through old_moduleMethod...
 };
 return my;
}(MODULE));

這里我們已經(jīng)重寫了MODULE.moduleMethod,還按照需求保留了對(duì)原始方法的引用。

復(fù)制和繼承

代碼如下:

var MODULE_TWO = (function (old) {
 var my = {},
  key;
 for (key in old) {
  if (old.hasOwnProperty(key)) {
   my[key] = old[key];
  }
 }
 var super_moduleMethod = old.moduleMethod;
 my.moduleMethod = function () {
  // override method on the clone, access to super through super_moduleMethod
 };
 return my;
}(MODULE));

這種模式可能是最不靈活的選擇。雖然它支持了一些優(yōu)雅的合并,但是代價(jià)是犧牲了靈巧性。在我們寫的代碼中,那些類型是對(duì)象或者函數(shù)的屬性不會(huì)被復(fù)制,只會(huì)以一個(gè)對(duì)象的兩份引用的形式存在。一個(gè)改變,另外一個(gè)也改變。對(duì)于對(duì)象來說[g5] ,我們可以通過一個(gè)遞歸的克隆操作來解決,但是對(duì)于函數(shù)是沒有辦法的,除了eval。然而,為了完整性我還是包含了它。

跨文件的私有狀態(tài)

把一個(gè)module分成多個(gè)文件有一很大的局限,就是每一個(gè)文件都在維持自身的私有狀態(tài),而且沒有辦法來獲得其他文件的私有狀態(tài)。這個(gè)是可以解決的,下面這個(gè)松拓展的例子,可以在不同文件中維持私有狀態(tài)。

代碼如下:

var MODULE = (function (my) {
 var _private = my._private = my._private || {},
  _seal = my._seal = my._seal || function () {
   delete my._private;
   delete my._seal;
   delete my._unseal;
  },
  _unseal = my._unseal = my._unseal || function () {
   my._private = _private;
   my._seal = _seal;
   my._unseal = _unseal;
  };
 // permanent access to _private, _seal, and _unseal
 return my;
}(MODULE || {}));

每一個(gè)文件可以為它的私有變量_private設(shè)置屬性,其他文件可以立即調(diào)用。當(dāng)module加載完畢,程序會(huì)調(diào)用MODULE._seal(),讓外部沒有辦法接觸到內(nèi)部的 _.private。如果之后module要再次拓展,某一個(gè)屬性要改變。在載入新文件前,每一個(gè)文件都可以調(diào)用_.unsea(),,在代碼執(zhí)行之后再調(diào)用_.seal。

這個(gè)模式在我今天的工作中想到的,我從沒有在其他地方見到過。但是我認(rèn)為這是一個(gè)很有用的模式,值得單獨(dú)寫出來。

Sub-modules

最后一個(gè)高級(jí)模式實(shí)際上是最簡(jiǎn)單的,有很多創(chuàng)建子module的例子,就像創(chuàng)建一般的module一樣的。

代碼如下:

MODULE.sub = (function () 
{ var my = {}; //
    ...
 return my;}());

雖然這可能是很簡(jiǎn)單的,但是我決定這值得被寫進(jìn)來。子module有一般的module所有優(yōu)質(zhì)的特性,包括拓展和私有狀態(tài)。

總結(jié)

大多數(shù)高級(jí)模式都可以互相組合來創(chuàng)建更有用的新模式。如果一定要讓我提出一個(gè)設(shè)計(jì)復(fù)雜應(yīng)用的方法的話,我會(huì)結(jié)合松拓展,私有狀態(tài),和子module。

在這里我沒有提到性能相關(guān)的事情,但是我可以說,module模式對(duì)于性能的提升有好處。它可以減少代碼量,這就使得代碼的載入更迅速。松拓展使得并行加載成為可能,這同樣提升的載入速度。初始化的時(shí)間可能比其他的方法時(shí)間長(zhǎng),但是這多花的時(shí)間是值得的。只要全局變量被正確導(dǎo)入了運(yùn)行的時(shí)候就不會(huì)出問題,在子module中由于對(duì)變量的引用鏈變短了可能也會(huì)提升速度。

最后,這是一個(gè)子module自身動(dòng)態(tài)加載的例子(如果不存在就創(chuàng)建),為了簡(jiǎn)介我沒有考慮內(nèi)部狀態(tài),但是即便考慮它也很簡(jiǎn)單。這個(gè)模式可以讓復(fù)雜,多層次的代碼并行的加載,包括子module和其他所有的東西。

代碼如下:

var UTIL = (function (parent, $) {
 var my = parent.ajax = parent.ajax || {};
 my.get = function (url, params, callback) {
  // ok, so I'm cheating a bit 
  return $.getJSON(url, params, callback);
 };
 // etc...
 return parent;
}(UTIL || {}, jQuery));

我希望這些內(nèi)容是有用的,請(qǐng)?jiān)谙旅媪粞詠矸窒砟愕南敕āI倌陚?,努力吧,寫出更好的,更模塊化的JavaScript。

以上就是JavaScript的Module模式編程是什么,小編相信有部分知識(shí)點(diǎn)可能是我們?nèi)粘9ぷ鲿?huì)見到或用到的。希望你能通過這篇文章學(xué)到更多知識(shí)。更多詳情敬請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

網(wǎng)站標(biāo)題:JavaScript的Module模式編程是什么
當(dāng)前鏈接:http://bm7419.com/article16/jdddgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、移動(dòng)網(wǎng)站建設(shè)做網(wǎng)站、微信小程序、網(wǎng)站營(yíng)銷、網(wǎng)站設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名