解析Javascript設(shè)計模式Revealing?Module?揭示模式單例模式
1. Revealing Module 揭示模式
該模式能夠在私有范圍內(nèi)簡單定義所有的函數(shù)和變量,并返回一個匿名對象, 它擁有指向私有函數(shù)的指針,該函數(shù)是他希望展示為公有的方法。
示例:
<script>
var myRevealingModule = function () {
var privateVar = "Ren Cherry",
publicVar = "Hey there";
function privateFunction() {
console.log("Name:"+privateVar);
}
function publicSetName(strName) {
privateName = strName;
}
function publicGetName() {
privateFunction();
}
//將暴露的公有指針指向到私有函數(shù)和屬性上
return {
setName: publicSetName,
greeting: publicvar,
getName: publicGetName
};
}();
myRevealingModule.setName("Paul Kinlan");
</script>
優(yōu)點:
- 該模式很容易之處哪些函數(shù)和變量可被公開訪問,改善了可讀性。
- 如果一個私有函數(shù)引用一個公有函數(shù),在需要打補丁時,公有函數(shù)是不能被覆蓋的。 因為私有函數(shù)將繼續(xù)引用私有實現(xiàn),該模式并不適用于公有成員,只使用函數(shù)。
2. Singleton 單例模式
單例模式,能夠限制類的實例化次數(shù)只能為一次。單例模式,在該實例不存在的情況下, 可以通過一個方法創(chuàng)建一個類來實現(xiàn)創(chuàng)建類的新實例;如果實例已經(jīng)存在,它會簡單返回該對象的引用;
示例:
<script type="text/javascript">
var mySingleton = (function () {
//實例保持了singleton 的一個引用
var instance;
function init() {
//singleton
//私有方法和變量
function privateMethod() {
console.log("I am private");
}
var privateVariable = "I am also private";
var privateRandomNumber = Math.random();
return {
//公有方法和變量
publicMethod: function () {
console.log("The public can see me!");
},
publicProperty: "I am also public",
getRandomNumber: function() {
return privateRandomNumber;
}
};
};
return {
//獲取singleton 的實例,如果存在就返回,不存在就創(chuàng)建新實例
getInstance: function() {
if(!instance) {
instance = init();
}
return instance;
}
};
})();
var singleA = mySingleton.getInstance();
var singleB = mySingleton.getInstance();
console.log(singleA.getRandomNumber()===singleB.getRandomNumber());//true
</script>
在實踐中,當在系統(tǒng)中確實需要一個對象來協(xié)調(diào)其他對象時,>Singleton模式很有用。
示例:
<script type="text/javascript">
var SingletonTester = (function() {
//options: 包含singleton所需配置信息的對象
//var options = {name:"test",pointX:5};
function Singleton(options) {
//如果未提供options,則設(shè)置為空對象
options = options || {};
//為singleton設(shè)置一些屬性
this.name = "SingletonTester";
this.pointX = options.pointX || 6;
this.pointY = options.pointY || 10;
}
//實例持有者
var instance;
//靜態(tài)變量和方法的模擬
var _static = {
name: "SingletonTester",
//獲取實例的方法,返回singleton對象的singleton實例
getInstance: function(options) {
if(instance === undefined) {
instance = new Singleton(options);
}
return instance;
};
return _static;
}
})();
var singletonTest = SingletonTester.getInstance({
pointX: 5
});
console.log(singletonTest.pointX);//5
</script>以上就是解析Javascript設(shè)計模式Revealing Module 揭示模式單例模式的詳細內(nèi)容,更多關(guān)于JS 揭示模式單例模式的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
微信小程序-getUserInfo回調(diào)的實例詳解
這篇文章主要介紹了微信小程序-getUserInfo回調(diào)的實例詳解的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下2017-10-10
關(guān)于Javascript閉包與應(yīng)用的詳解
這篇文章主要介紹了關(guān)于Javascript閉包與應(yīng)用的詳解,文中有非常詳細的代碼示例.對正在學習js的伙伴們有很好的幫助,需要的朋友可以參考下2021-04-04
autojs長寬不定的圖片在正方形圖片居中實現(xiàn)詳解
這篇文章主要為大家介紹了autojs長寬不定的圖片在正方形圖片居中實現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01
實現(xiàn)基于飛書webhook監(jiān)聽github代碼提交
這篇文章主要為大家介紹了實現(xiàn)基于飛書webhook監(jiān)聽github代碼提交示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-01-01

