Сведения о вопросе

Fedya

16:57, 3rd August, 2020

Теги

Как обеспечить пространства имен в JavaScript экземплярами объектов

Просмотров: 439   Ответов: 5

У меня есть JavaScript "object", построенный таким образом:

function foo()
{
    this.length = 0;
}

foo.prototype.getLength = function()
{
    return this.length;
}

...

Я знаю, как эмулировать пространства имен с объектами singleton JavaScript, но как лучше всего использовать объект "namepace", такой как выше, который будет intanced?

Я знаю, что несколько библиотек JavaScript имеют возможности размещения имен, но я использую jQuery и предпочел бы не добавлять еще одну библиотеку в микс. Я хотел бы иметь возможность предоставить свою собственную, возможно, используя jQuery, внутреннюю схему пространства имен для JS моих объектов,которые должны быть созданы.

Спасибо армированный пластик



  Сведения об ответе

davran

08:33, 28th August, 2020

Простой:

if(!MyNamespace) MyNamespace = {};

MyNamespace.foo = function() {
   this.length = 0;
};
MyNamespace.foo.prototype.getLength = function() {
   return this.length;
};


  Сведения об ответе

prince

02:09, 20th August, 2020

Javascript на самом деле не имеет пространства имен или пакетов, как другие языки. Вместо этого он имеет closures. Если у вас есть приложение, которое состоит из нескольких функций, переменных и объектов, то вы должны поместить их в один глобальный объект. Это будет иметь тот же эффект, что и пространство имен.

Например:

var namespace = {
  this.foo: function(){
    ...
  },
  this.foo.prototype.getLength: function(){
    ...
  }
}

Можно также создать набор вложенных объектов и имитировать пакеты:

loadPackage = function(){
  var path = arguments[0];
  for(var i=1; i<arguments.length; i++){
    if(!path[arguments[i]]){
      path[arguments[i]] = {};
    }
    path = path[arguments[i]];
  }
  return path;
}

loadPackage(this, "com", "google", "mail") = {
  username: "gundersen",
  login: function(password){
    ...
  }
}
this.com.google.mail.login("mySecretPassword");


  Сведения об ответе

davran

19:15, 21st August, 2020

Не должно было сильно отличаться:

namespace.foo = function foo() {...}
namespace.foo.prototype.getLength = function() { ... }

или вы могли бы использовать

(function() {
  function foo() { ... }
  foo.prototype...
  namespace.foo = foo;
})();

чтобы сэкономить время на вводе текста.


  Сведения об ответе

DO__IT

21:17, 5th August, 2020

Оба ответа были очень полезны! Вот что у меня получилось:

if( typeof( rpNameSpace ) == "undefined" ) rpNameSpace = {};

rpNameSpace.foo = function() {
    this.length = 613;
}
rpNameSpace.foo.prototype.getLength = function() {
    return this.length * 2;
}

Затем, чтобы использовать полученный объект "namespaced":

var x = new rpNameSpace.foo()

display( x.getLength() );


  Сведения об ответе

DINO

17:33, 20th August, 2020

Другой альтернативой может быть фреймворк bob.js :

bob.ns.setNs('myApp.myFunctions', { 
    say: function(msg) {  
        console.log(msg); 
    } 
}); 

//sub-namespace
bob.ns.setNs('myApp.myFunctions.mySubFunctions', { 
    hello: function(name) { 
        myApp.myFunctions.say('Hello, ' + name); 
    } 
}); 

//call:
myApp.myFunctions.mySubFunctions.hello('Bob'); 


Ответить на вопрос

Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться