我是中等水平的 javascript 开发人员,试图了解骨干库在内部是如何工作的,如果有人帮助我解决一些挑战,我将不胜感激。
所以这就是我的理解
Backbone 中构造函数的基本定义是
Backbone.Model = function(attributes, options) { }
然后他们使用通用的扩展方法在我们的构造函数的原型中添加通用特性。
_.extend(Backbone.Model.prototype, Backbone.Events, {...})
现在直到这部分我确切地知道发生了什么,并且很乐意通过以下代码实例化新对象
var user = new Backbone.Model()
这是我发现具有挑战性的部分
当然这不是我们在 Backbone 中实例化对象的方式,而是我们使用扩展方法
var Users = Backbone.Model.extend({});
var user = new Users()
在主干代码中
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;
};
请解释一下继承函数内部发生了什么以及扩展方法方法的好处是什么