我是一位中等水平的JavaScript開發人員,他試圖理解骨幹庫如何在內部工作,並且如果有人幫助我解決一些挑戰,我會深表感謝。解釋骨幹對象和類創建模式
所以在這裏我是這樣理解的骨幹
構造函數的基本定義是
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;
};
請給我解釋一下發生了什麼內部的繼承函數,什麼是擴展方法方法的好處
骨幹與評論來源:http://documentcloud.github.com/backbone/docs/backbone.html搜索的繼承方法。他們有一個很好的描述。 – jForrest 2012-08-16 14:12:22