3

我正在尝试在命名空间中创建一个函数,该函数将为我提供一个新的对象实例。

尝试执行以下操作时出现语法错误:

var namespace = {
    a : function(param){
        this.something = param;
    },
    a.prototype.hi = function(){
        alert('hi');
    },

    b : function(){
        var t = new a('something');
    }
};

这样做的正确语法是什么?不能在namespace对象内做吗?我不想先声明命名空间。谢谢

4

3 回答 3

7

我不想先声明命名空间。

你可以做这样奇怪的事情:

var namespace = {
    init: function() { 
        a.prototype.whatever = function(){};
    },
    a: function(x) {
        this.x = x;
    }  
}
namespace.init();
var myA = new namespace.a("x");

但是,如果您想封装所有内容,为什么不尝试模块模式呢?它更清洁:

var namespace = (function() {
     function a() {};
     function b(name) {
          this.name = name;
     };
     b.prototype.hi = function() {
          console.log("my name is " + this.name);
     }
     return {
          a: a,
          b: b
     }
})();
于 2012-12-03T16:17:52.853 回答
0

javascript 命名空间是一个对象,因此您只能使用一对key: value但不能使用代码(就像您使用 : 一样a.prototype.hi = function() {...})。

因此,您应该将其分为两部分:声明,然后是代码:

var namespace = {
    a : function(param){
        this.something = param;
    },
    b : function(){
        var t = new a('something');
    }
};

namespace.a.prototype.hi : function() { ... }
于 2012-12-03T16:13:30.817 回答
0

我不完全知道你想要什么,但这有效:

var namespace = {

    a: function() {

        function a() {

        }

        a.prototype.hi = function() {
            console.log("hi");
        }

        return new a;

    }

}

var obj = new namespace.a();
obj.hi()

// -> 'hi'
于 2012-12-03T16:19:55.587 回答