Soy un desarrollador de JavaScript de nivel moderado que intenta comprender cómo funciona la biblioteca de backbone internamente y agradecería profundamente si alguien me ayudara a resolver algunos desafíos.explicar el objeto de backbone y el patrón de creación de clase
así que aquí es lo que entiendo
definición básica de la función constructora en Backbone está
Backbone.Model = function(attributes, options) { }
luego usan para fines generales extender método para agregar características comunes en nuestro prototipo del constructor.
_.extend(Backbone.Model.prototype, Backbone.Events, {...})
ahora hasta esta parte sé exactamente lo que está sucediendo y estaremos encantados de crear una instancia de objeto nuevo, aunque siguiente código
var user = new Backbone.Model()
y esta es la parte que estoy encontrando difícil
por supuesto, no es la forma en que instanciamos un objeto en Backbone, pero utilizamos extender el método
var Users = Backbone.Model.extend({});
var user = new Users()
y en el código de la columna vertebral
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;
};
por favor me explique lo que está sucediendo dentro de la función de heredar y cuál es el beneficio de ampliar el enfoque método
Backbone tiene origen con los comentarios: http://documentcloud.github.com/backbone/docs/backbone.html Busca el método hereda. Tienen una buena descripción. – jForrest