javascript設(shè)計(jì)模式之模塊模式學(xué)習(xí)筆記
我們通過單體模式理解了是以對(duì)象字面量的方式來創(chuàng)建單體模式的;比如如下的對(duì)象字面量的方式代碼如下:
var singleMode = { name: value, method: function(){ } };
模塊模式的思路是為單體模式添加私有變量和私有方法能夠減少全局變量的使用;如下就是一個(gè)模塊模式的代碼結(jié)構(gòu):
var singleMode = (function(){ // 創(chuàng)建私有變量 var privateNum = 112; // 創(chuàng)建私有函數(shù) function privateFunc(){ // 實(shí)現(xiàn)自己的業(yè)務(wù)邏輯代碼 } // 返回一個(gè)對(duì)象包含公有方法和屬性 return { publicMethod1: publicMethod1, publicMethod2: publicMethod1 }; })();
模塊模式使用了一個(gè)返回對(duì)象的匿名函數(shù)。在這個(gè)匿名函數(shù)內(nèi)部,先定義了私有變量和函數(shù),供內(nèi)部函數(shù)使用,然后將一個(gè)對(duì)象字面量作為函數(shù)的值返回,返回的對(duì)象字面量中只包含可以公開的屬性和方法。這樣的話,可以提供外部使用該方法;由于該返回對(duì)象中的公有方法是在匿名函數(shù)內(nèi)部定義的,因此它可以訪問內(nèi)部的私有變量和函數(shù)。
我們什么時(shí)候使用模塊模式?
如果我們必須創(chuàng)建一個(gè)對(duì)象并以某些數(shù)據(jù)進(jìn)行初始化,同時(shí)還要公開一些能夠訪問這些私有數(shù)據(jù)的方法,那么我們這個(gè)時(shí)候就可以使用模塊模式了。
理解增強(qiáng)的模塊模式
增強(qiáng)的模塊模式的使用場(chǎng)合是:適合那些單列必須是某種類型的實(shí)例,同時(shí)還必須添加某些屬性或方法對(duì)其加以增強(qiáng)的情況。比如如下代碼:
function CustomType() { this.name = "tugenhua"; }; CustomType.prototype.getName = function(){ return this.name; } var application = (function(){ // 定義私有 var privateA = "aa"; // 定義私有函數(shù) function A(){}; // 實(shí)例化一個(gè)對(duì)象后,返回該實(shí)例,然后為該實(shí)例增加一些公有屬性和方法 var object = new CustomType(); // 添加公有屬性 object.A = "aa"; // 添加公有方法 object.B = function(){ return privateA; } // 返回該對(duì)象 return object; })();
下面我們來打印下application該對(duì)象;如下:
console.log(application);
繼續(xù)打印該公有屬性和方法如下:
console.log(application.A);// aa console.log(application.B()); // aa console.log(application.name); // tugenhua console.log(application.getName());// tugenhua
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Javascript模塊模式分析
- Javascript的一種模塊模式
- 深入理解JavaScript中的塊級(jí)作用域、私有變量與模塊模式
- JavaScript 設(shè)計(jì)模式 安全沙箱模式
- javascript 模式設(shè)計(jì)之工廠模式學(xué)習(xí)心得
- JavaScript設(shè)計(jì)模式之觀察者模式(發(fā)布者-訂閱者模式)
- JavaScript 設(shè)計(jì)模式之組合模式解析
- javascript設(shè)計(jì)模式之解釋器模式詳解
- 常用的Javascript設(shè)計(jì)模式小結(jié)
- JavaScript設(shè)計(jì)模式之工廠方法模式介紹
- JavaScript設(shè)計(jì)模式之單例模式實(shí)例
- JavaScript模塊模式實(shí)例詳解
相關(guān)文章
詳解JavaScript如何優(yōu)雅地實(shí)現(xiàn)創(chuàng)建多維數(shù)組
多維數(shù)組的意思是指三維或者三維以上的數(shù)組。這篇文章將通過示例為大家詳細(xì)講解一下JavaScript如何實(shí)現(xiàn)優(yōu)雅地創(chuàng)建多維數(shù)組,需要的可以參考一下2022-07-07Javascript實(shí)現(xiàn)基本運(yùn)算器
這篇文章主要為大家詳細(xì)介紹了Javascript實(shí)現(xiàn)基本運(yùn)算器的相關(guān)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07簡單談?wù)刼ffsetleft、offsetTop和offsetParent
這篇文章主要給大家介紹了offsetleft、offsetTop和offsetParent的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12微信小程序防止多次點(diǎn)擊跳轉(zhuǎn)和防止表單組件輸入內(nèi)容多次驗(yàn)證功能(函數(shù)防抖)
這篇文章主要介紹了微信小程序防止多次點(diǎn)擊跳轉(zhuǎn)和防止表單組件輸入內(nèi)容多次驗(yàn)證功能(函數(shù)防抖),需要的朋友可以參考下2019-09-09uniapp原生tabbar設(shè)置并添加數(shù)字角標(biāo)或小紅點(diǎn)提示功能
這篇文章主要給大家介紹了關(guān)于uniapp原生tabbar設(shè)置并添加數(shù)字角標(biāo)或小紅點(diǎn)提示功能的相關(guān)資料,在相應(yīng)的頁面中完成對(duì)消息的處理,如果有新消息,則在tabBar頁面中顯示紅點(diǎn)提醒用戶,需要的朋友可以參考下2023-08-08uniapp實(shí)現(xiàn)微信一鍵登錄按鈕樣式(膠囊按鈕的樣式)
這篇文章主要介紹了uniapp實(shí)現(xiàn)微信一鍵登錄按鈕樣式,如何開發(fā)膠囊按鈕的樣式,需要的朋友可以參考下2024-07-07利用javascript實(shí)現(xiàn)禁用網(wǎng)頁上所有文本框,下拉菜單,多行文本域
這篇文章主要介紹了利用javascript實(shí)現(xiàn)禁用網(wǎng)頁上所有文本框,下拉菜單,多行文本域。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-12-12禁用頁面部分JavaScript方法的具體實(shí)現(xiàn)
方法重寫,重寫要禁用的方法,并讓它什么也不做,結(jié)果證明真的可行,但并不知道是不是一個(gè)科學(xué)的方法,我拿出來與大家共同討論一下2013-07-07