- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我有一个包含大量模型的 Backbone 集合。
每当在模型上设置特定属性并保存它时,就会触发大量计算并重新呈现 UI。
但是,我希望能够同时在多个模型上设置属性,并且只在所有设置完成后才进行保存和重新渲染。当然,我不想为一次操作发出多个 http 请求,也绝对不想重新呈现界面十次。
我希望在 Backbone.Collection 上找到一个保存方法,它可以计算出哪些模型 hasChanged(),将它们作为 json 组合在一起并发送到后端。然后可以通过集合上的事件触发重新渲染。没有这样的运气。
这似乎是一个很常见的要求,所以我想知道为什么 Backbone 没有实现。这是否违反 RESTful 架构,将多个内容保存到单个端点?如果是这样,那又怎样?发出 1000 个请求来持久化 1000 个小项目是不可能的。
那么,使用我自己的保存方法来扩充 Backbone.Collection 的唯一解决方案是遍历其所有模型并为所有已更改的模型构建 json 并将其发送到后端吗?或者有没有人有更简洁的解决方案(或者我只是遗漏了什么!)?
最佳答案
我最终用几种方法来扩充 Backbone.Collection 来处理这个问题。
saveChangeMethod 创建一个虚拟模型以传递给 Backbone.sync。模型的所有主干同步方法都需要它的 url 属性和 toJSON 方法,因此我们可以轻松地解决这个问题。
在内部,模型的 toJSON 方法仅返回其属性的副本(将发送到服务器),因此我们可以愉快地使用仅返回模型数组的 toJSON 方法。 Backbone.sync 对此进行字符串化,这只为我们提供了属性数据。
成功时,saveChanged 触发集合上的事件以处理一次。加入了一些代码,使其针对任何批处理模型中已更改的每个属性触发一次特定事件。
Backbone.Collection.prototype.saveChanged = function () {
var me = this,
changed = me.getChanged(),
dummy = {
url: this.url,
toJSON: function () {
return changed.models;
}
},
options = {
success: function (model, resp, xhr) {
for (var i = 0; i < changed.models.length; i++) {
changed.models[i].chnageSilently();
}
for (var attr in changed.attributes) {
me.trigger("batchchange:" + attr);
}
me.trigger("batchsync", changed);
}
};
return Backbone.sync("update", dummy, options);
}
然后我们只需要集合上的 getChanged() 方法。这将返回一个具有 2 个属性的对象,一个已更改模型的数组和一个标记哪些属性已更改的对象:
Backbone.Collection.prototype.getChanged = function () {
var models = [],
changedAttributes = {};
for (var i = 0; i < this.models.length; i++) {
if (this.models[i].hasChanged()) {
_.extend(changedAttributes, this.models[i].changedAttributes());
models.push(this.models[i]);
}
}
return models.length ? {models: models, attributes: changedAttributes} : null;
}
虽然这是对主干“更改模型”范例的预期用途的轻微滥用,但批处理的全部意义在于我们不希望在模型更改时发生任何事情(即触发任何事件)。
因此,我们必须将 {silent: true} 传递给模型的 set() 方法,因此使用 backbone 的 hasChanged() 来标记等待保存的模型是有意义的。当然,如果您出于其他目的静默更改模型,这将会有问题 - collection.saveChanged() 也会保存这些,因此值得考虑设置一个替代标志。
无论如何,如果我们这样做,在保存时,我们需要确保 backbone 现在认为模型没有改变(不触发它们的改变事件),所以我们需要手动操作模型,就好像它没有改变。 saveChanged() 方法迭代我们更改的模型并在模型上调用这个 changeSilently() 方法,它基本上只是没有触发器的 Backbone 的 model.change() 方法:
Backbone.Model.prototype.changeSilently = function () {
var options = {},
changing = this._changing;
this._changing = true;
for (var attr in this._silent) this._pending[attr] = true;
this._silent = {};
if (changing) return this;
while (!_.isEmpty(this._pending)) {
this._pending = {};
for (var attr in this.changed) {
if (this._pending[attr] || this._silent[attr]) continue;
delete this.changed[attr];
}
this._previousAttributes = _.clone(this.attributes);
}
this._changing = false;
return this;
}
用法:
model1.set({key: value}, {silent: true});
model2.set({key: value}, {silent: true});
model3.set({key: value}, {silent: true});
collection.saveChanged();
回复。 RESTfulness .. 对集合的端点执行 PUT 以更改其“某些”记录是不太正确的。从技术上讲,PUT 应该替换整个集合,但在我的应用程序真正需要替换整个集合之前,我很乐意采用务实的方法。
关于javascript - 一次保存多个 Backbone 模型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12287359/
可不可以命名为MVVM模型?因为View通过查看模型数据。 View 是否应该只与 ViewModelData 交互?我确实在某处读到正确的 MVVM 模型应该在 ViewModel 而不是 Mode
我正在阅读有关设计模式的文章,虽然作者们都认为观察者模式很酷,但在设计方面,每个人都在谈论 MVC。 我有点困惑,MVC 图不是循环的,代码流具有闭合拓扑不是很自然吗?为什么没有人谈论这种模式: mo
我正在开发一个 Sticky Notes 项目并在 WPF 中做 UI,显然将 MVVM 作为我的架构设计选择。我正在重新考虑我的模型、 View 和 View 模型应该是什么。 我有一个名为 Not
不要混淆:How can I convert List to Hashtable in C#? 我有一个模型列表,我想将它们组织成一个哈希表,以枚举作为键,模型列表(具有枚举的值)作为值。 publi
我只是花了一些时间阅读这些术语(我不经常使用它们,因为我们没有任何 MVC 应用程序,我通常只说“模型”),但我觉得根据上下文,这些意味着不同的东西: 实体 这很简单,它是数据库中的一行: 2) In
我想知道你们中是否有人知道一些很好的教程来解释大型应用程序的 MVVM。我发现关于 MVVM 的每个教程都只是基础知识解释(如何实现模型、 View 模型和 View ),但我对在应用程序页面之间传递
我想realm.delete() 我的 Realm 中除了一个模型之外的所有模型。有什么办法可以不列出所有这些吗? 也许是一种遍历 Realm 中当前存在的所有类型的方法? 最佳答案 您可以从您的 R
我正在尝试使用 alias 指令模拟一个 Eloquent 模型,如下所示: $transporter = \Mockery::mock('alias:' . Transporter::class)
我正在使用 stargazer 创建我的 plm 汇总表。 library(plm) library(pglm) data("Unions", package = "pglm") anb1 <- pl
我读了几篇与 ASP.NET 分层架构相关的文章和问题,但是读得太多后我有点困惑。 UI 层是在 ASP.NET MVC 中开发的,对于数据访问,我在项目中使用 EF。 我想通过一个例子来描述我的问题
我收到此消息错误: Inceptionv3.mlmodel: unable to read document 我下载了最新版本的 xcode。 9.4 版测试版 (9Q1004a) 最佳答案 您没有
(同样,一个 MVC 验证问题。我知道,我知道......) 我想使用 AutoMapper ( http://automapper.codeplex.com/ ) 来验证我的创建 View 中不在我
需要澄清一件事,现在我正在处理一个流程,其中我有两个 View 模型,一个依赖于另一个 View 模型,为了处理这件事,我尝试在我的基本 Activity 中注入(inject)两个 View 模型,
如果 WPF MVVM 应该没有代码,为什么在使用 ICommand 时,是否需要在 Window.xaml.cs 代码中实例化 DataContext 属性?我已经并排观看并关注了 YouTube
当我第一次听说 ASP.NET MVC 时,我认为这意味着应用程序由三个部分组成:模型、 View 和 Controller 。 然后我读到 NerdDinner并学习了存储库和 View 模型的方法
Platform : ubuntu 16.04 Python version: 3.5.2 mmdnn version : 0.2.5 Source framework with version :
我正在学习本教程:https://www.raywenderlich.com/160728/object-oriented-programming-swift ...并尝试对代码进行一些个人调整,看看
我正试图围绕 AngularJS。我很喜欢它,但一个核心概念似乎在逃避我——模型在哪里? 例如,如果我有一个显示多个交易列表的应用程序。一个列表向服务器查询匹配某些条件的分页事务集,另一个列表使用不同
我在为某个应用程序找出最佳方法时遇到了麻烦。我不太习惯取代旧 TLA(三层架构)的新架构,所以这就是我的来源。 在为我的应用程序(POCO 类,对吧??)设计模型和 DAL 时,我有以下疑问: 我的模
我有两个模型:Person 和 Department。每个人可以在一个部门工作。部门可以由多人管理。我不确定如何在 Django 模型中构建这种关系。 这是我不成功的尝试之一 [models.py]:
我是一名优秀的程序员,十分优秀!