Ich schrieb eine kleine Angular1 App, die einen Datenbankdienst hat, der LokiJS verwendet. Ich frage mich, ob es eine Möglichkeit gibt, Eigenschaften/Funktionen dynamisch zu einem Service/Factory hinzuzufügen.Dynamische Hinzufügen von Eigenschaften/Funktionen zu einem Service/Fabrik
Ich versuche dynamische Getter für jede Sammlung hinzuzufügen, die über diesen Dienst erstellt wird.
Hier mein Beispiel:
Database.js
angular.module('MyApp')
.factory('Database', ['$log', '$q', 'Loki',
function Database($log, $q, Loki)
{
var _db,
dbInitialized = false;
function init(config)
{
// some logic here
}
function addCollection(name, cfg) {
// some logic here
_db.addCollection(name, cfg);
// this doesnt work, but is desired ->
/*this['get'+name] = this.getCollection.bind(this, name);*/
}
function getCollection(collectionName) {
// some logic here
return something;
}
return {
init: init,
addCollection: addCollection,
getCollection: getCollection
};
}
]
);
app.js
angular
.module('MyApp', ['lokijs'])
.run(['Database',
function (Database) {
Database.init();
Database.addCollection("MyCollection", {});
// then fill collection, afterwards ->
var collection = Database.getCollection("MyCollection");
// I would like to use Database.getMyCollection()
}]);;
Gibt es eine Möglichkeit, eine initialisierte Service/Fabrik zu ändern?
Die Frage erklärt nicht, warum 'this ['get' + name] = this.getCollection.bind (this, name)' nicht funktioniert. Wenn der 'addCollection'-Aufruf vor 'get *' steht, sollte es funktionieren. – estus
Ihr Code sollte gut funktionieren. Haben Sie einen Fehler? – dfsq
Sorry Frage war unnötig ... Alles ist in Ordnung mit diesem ['Get' + Name] = this.getCollection.bind (this, name) – kerosene