Sono uno sviluppatore javascript di livello moderato che sta cercando di capire come la libreria backbone funziona internamente e apprezzerà profondamente se qualcuno mi aiuta a risolvere alcune sfide.spiegare l'oggetto backbone e il modello di creazione della classe
ecco quello che ho capito
definizione di base di funzione di costruzione di backbone è
Backbone.Model = function(attributes, options) { }
poi uso generale metodo extend per aggiungere caratteristiche comuni nel prototipo del nostro costruttore.
_.extend(Backbone.Model.prototype, Backbone.Events, {...})
ora fino a questa parte io so esattamente che cosa sta accadendo e sarebbe felice di istanziare nuovo oggetto se seguente codice
var user = new Backbone.Model()
e questa è la parte mi sto trovando difficile
naturalmente non è il modo in cui istanziamo un oggetto in Backbone ma usiamo il metodo di estensione
var Users = Backbone.Model.extend({});
var user = new Users()
e nel codice dorsale
Backbone.Model.extend = extend;
var extend = function(protoProps, classProps) {
var child = inherits(this, protoProps, classProps);
child.extend = this.extend;
return child;
};
var inherits = function(parent, protoProps, staticProps) {
var child;
if (protoProps && protoProps.hasOwnProperty('constructor')) {
child = protoProps.constructor;
} else {
child = function() {
return parent.apply(this, arguments);
};
}
_.extend(child, parent);
ctor.prototype = parent.prototype;
child.prototype = new ctor();
if (protoProps) _.extend(child.prototype, protoProps);
if (staticProps) _.extend(child, staticProps);
child.prototype.constructor = child;
child.__super__ = parent.prototype;
return child;
};
si prega di spiegare a me che cosa sta accadendo all'interno funzione di ereditare e che cosa è il vantaggio di estendere l'approccio metodo
Backbone ha origine con i commenti: http://documentcloud.github.com/backbone/docs/backbone.html Ricerca per il metodo eredita. Hanno una bella descrizione. – jForrest