Backbone 框架背后的策略是使其易于编辑并灵活地满足各种需求。因此,如果您查看源代码,您会发现调用 Backbone.sync 的每个方法实际上都首先调用“this.sync”。
从 Backbone 手册中,您可以阅读:
通过将同步函数添加到 Backbone 集合或单个模型,可以将同步函数作为 Backbone.sync 全局覆盖,或者在更细粒度的级别上覆盖。
所以你有两个选择
选项一 - 替换全局 Backbone.sync 函数
如果您覆盖全局 Backbone.sync 您应该将代码放在全局应用程序文件中(实际上是您想要的任何位置,但必须在初始 javascript 加载时对其进行评估(执行),才能按预期工作
// Anywhere you want
Backbone.sync = function(method, collection, options) {
console.log(method, collection options)
}
这将覆盖 Backbone.sync 并且实际上将在您的控制台上显示每次调用 collection.fetch、保存、删除等时调用的内容。
在这里你没有默认的 Methodmap,事实上你除了参数之外什么都没有:
- 方法 - 这是一个字符串 - 'read', 'create', 'delete', 'update'
- 集合 - 这是您调用该方法的集合实例
- 选项 - 具有一些成功、错误功能,您可能会保留也可能不会保留。
在你的浏览器中调试这个,在阅读 Backbone 源代码的同时,它很容易理解。
选项二 - 添加到您的模型/集合同步方法
如果您希望对所有其他模型/集合使用默认 Backbone.sync 方法,则使用此方法,除了您专门定义的模型/集合:
mySocketModel = Backbone.Model.extend({
sync : function(method, collection, options) {
console.log('socket collection '+this.name+' sync called');
}
});
Partners = new mySocketModel({ name : 'partners' });
Users = new mySocketModel({ name : 'users' });
Log = new Backbone.Collection;
因此,如果您调用 Partners.fetch() 或 Users.fetch(),它们将不再调用 Backbone.sync,但您的 Log.fetch() 方法会。