溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Javascript設(shè)計(jì)模式Revealing?Module揭示模式怎么實(shí)現(xiàn)

發(fā)布時(shí)間:2022-08-25 14:36:19 來源:億速云 閱讀:139 作者:iii 欄目:開發(fā)技術(shù)

這篇“Javascript設(shè)計(jì)模式Revealing Module揭示模式怎么實(shí)現(xiàn)”文章的知識點(diǎn)大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細(xì),步驟清晰,具有一定的借鑒價(jià)值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Javascript設(shè)計(jì)模式Revealing Module揭示模式怎么實(shí)現(xiàn)”文章吧。

1. Revealing Module 揭示模式

該模式能夠在私有范圍內(nèi)簡單定義所有的函數(shù)和變量,并返回一個(gè)匿名對象, 它擁有指向私有函數(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)點(diǎn):

  • 該模式很容易之處哪些函數(shù)和變量可被公開訪問,改善了可讀性。

  • 如果一個(gè)私有函數(shù)引用一個(gè)公有函數(shù),在需要打補(bǔ)丁時(shí),公有函數(shù)是不能被覆蓋的。 因?yàn)樗接泻瘮?shù)將繼續(xù)引用私有實(shí)現(xiàn),該模式并不適用于公有成員,只使用函數(shù)。

2. Singleton 單例模式

單例模式,能夠限制類的實(shí)例化次數(shù)只能為一次。單例模式,在該實(shí)例不存在的情況下, 可以通過一個(gè)方法創(chuàng)建一個(gè)類來實(shí)現(xiàn)創(chuàng)建類的新實(shí)例;如果實(shí)例已經(jīng)存在,它會簡單返回該對象的引用;

示例:

<script type="text/javascript">
var mySingleton = (function () {
        //實(shí)例保持了singleton 的一個(gè)引用
        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 的實(shí)例,如果存在就返回,不存在就創(chuàng)建新實(shí)例
                getInstance: function() {
                        if(!instance) {
                                instance = init();
                        }
                        return instance;
                }
        };
})();
var singleA = mySingleton.getInstance();
var singleB = mySingleton.getInstance();
console.log(singleA.getRandomNumber()===singleB.getRandomNumber());//true
</script>

在實(shí)踐中,當(dāng)在系統(tǒng)中確實(shí)需要一個(gè)對象來協(xié)調(diào)其他對象時(shí),>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;
        }
        //實(shí)例持有者
        var instance;
        //靜態(tài)變量和方法的模擬
        var _static = {
                name: "SingletonTester",
                //獲取實(shí)例的方法,返回singleton對象的singleton實(shí)例
                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>

以上就是關(guān)于“Javascript設(shè)計(jì)模式Revealing Module揭示模式怎么實(shí)現(xiàn)”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI