Javascript 设计模式 -- Revealing Module(揭示模块)模式

这是对Module模式的一个改进版本。方便集中管理公有API,使公有API更简洁清楚。

var myRevealingModule = function () {

    var privateVar = "Ben Cherry",
        publicVar = "Hey there";

    function privateFunction() {
        console.log("Name: " + privateVar);
    }

    function publicSetName(strName) {
        var privateName = strName;
    }

    function publicGetName () {
        privateFunction();
    }

    // 将暴露的公有指针指向私有函数和属性上
    return {
        setName: publicSetName,
        greeting: publicVar,
        getName: publicGetName
    };
}();

myRevealingModule.setName("Paul Kinlan");
console.log(myRevealingModule.greeting);    // Hey there
myRevealingModule.getName();                // Name: Ben Cherry

优点:该模式可以使脚本语法更加一致。在模块代码底部,它会很容易指出哪些函数和变量可以被公开访问,从而改善可读性。
缺点:如果一个私有函数医用一个公有函数,在需要打补丁时,个哦剛女友函数是不能被覆盖的。这是因为私有函数将继续引用私有实现,该模式不适用与公有成员,只适用于函数。
引用私有变量的公有对象成员也遵守无补丁规则。

    原文作者:设计模式
    原文地址: https://segmentfault.com/a/1190000002434172
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞