1

好的,几周前,我了解了 javascript 中的“模块模式”。我发现的所有示例基本上都是这样的:

var module = (function () {
    // private variables and functions
    var foo = 'bar';

    // constructor
      var module = function () {
    };

    // public methods
    module.prototype = {
        something: function () {
        }
    };

    // return module
    return module;
})();

var my_module = new module();

我很兴奋,所以我立即开始了自己的测试:

var myModule = myModule || {};

myModule.User = (function(){
    "use strict";

    // "private" attribut
    var id

    //constructor
    var User = function(l_id){
        id = l_id;
    };

    //"public" method
    User.prototype.getId = function(){ return id };


    return User;
})();

var u2 = new myModule.User(2);
var u1 = new myModule.User(1);
console.log(u2.getId()); // print 2
console.log(u1.getId()); //print 2 oO

然而,我没想到所谓的“私有”属性“id”,并不是一个实例变量。如果我注意的话,我会注意到这样一个变量的范围......我严重误解了“私有变量和函数”的评论......

尽管如此,我还是决定找到一种在模块中使用私有实例变量的方法。

目前我发现的唯一解决方案是这种好方法:

myModule.User = (function(){
    "use strict";

    //constructor
    var User = function(id){        
        this.getId = function(){ return id; };
    };   

    return User;
})();

但是已经没有原型优势了......

您有更好的方法来混合“模块模式”和私有实例变量的使用吗?

4

1 回答 1

0

坦率地说,我从来没有将模块模式与构造函数一起使用,我觉得有更好的方法,但是要实现你正在寻找的东西(也就是说,如果我理解你是正确的)你可以这样做:

var PrefixModule = (function () {
    // this is going to be static ... also that's a real title !
    var staticTitle = "Intergalactic Federation King Almighty and Commander of the Universe";

    var PrefixModule = function () {
        // this is an instance variable
        this.secretPrefix = staticTitle + " ::";
    };

    // hidden from the world
    var generateRandomNumber = function() {
        return Math.floor(Math.random() * 100);
    };

    PrefixModule.prototype.PrefixName = function (name) {
        var randomNumber = generateRandomNumber();
        return this.secretPrefix + " " + name + " | " + randomNumber;
    };

    return PrefixModule;
})();

var m1 = new PrefixModule();
var m2 = new PrefixModule();
var m3 = new PrefixModule();

console.log(m1.PrefixName("Jon Skeet"));
console.log(m2.PrefixName("Chuck Norris"));
console.log(m3.PrefixName("vbarthel-fr"));

这是一个小提琴

另外,我应该澄清一下,在您的情况下,它id被设置为静态变量,并且在模块之间共享。希望能帮助到你。

于 2013-05-09T17:18:39.073 回答