- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我对 Backbone.js 比较陌生。我正在初始化一个 Collection View 并在创建时传入一个集合。
suggestionsView = new TreeCategoriesAutoSuggest.Views.Suggestions({
collection: new App.Collections.Suggestions(this.getSuggestions(query))
});
然后我渲染 Collection View 。每次用户在文本框中输入查询时,都会重新生成集合并使用以下方法将其分配给 Collection View :
suggestionsView.collection.set(this.getSuggestions(query));
这负责在集合中添加/删除模型,但我如何管理添加/删除添加/删除模型的 View ?
我应该提一下,我在 Collection View 中使用了 this.collection.on("add") 监听器。但这会为添加的每个模型触发。我还从单个 View 中尝试了 this.model.on("change"),但是当从集合中添加/删除模型时,这不会被触发。
感谢任何帮助/指导!
更新
我现在正在使用:
suggestionsView.collection.reset(this.getSuggestions(query));
当重置事件被触发时,我将删除建议 subview ,为新集合重新初始化它们并重新呈现 Collection View 。
handleReset: function(){
console.log("reset");
this.cleanupOldViews();
this.initViews();
},
initViews: function(){
this.collection.each(function(suggestion){
this.suggestionViews.push(new TreeCategoriesAutoSuggest.Views.Suggestion({
model: suggestion
}));
},this);
},
cleanupOldViews: function(){
_.each(this.suggestionViews,function(suggestionView){
suggestionView.remove()
},this);
this.suggestionViews = [];
}
所以你认为我不需要担心破坏模型?
最佳答案
使用 reset
可以更轻松、更高效地进行批量替换:
reset
collection.reset([models], [options])
Adding and removing models one at a time is all well and good, but sometimes you have so many models to change that you'd rather just update the collection in bulk. Use reset to replace a collection with a new list of models (or attribute hashes), triggering a single
"reset"
event at the end. Returns the newly-set models. For convenience, within a"reset"
event, the list of any previous models is available asoptions.previousModels
.
所以不用 set
合并更改并生成一堆 'add'
和 'remove'
事件,使用 reset
并监听 'reset'
事件:
// In the view's `initialize`...
this.listenTo(this.collection, 'reset', this.render);
然后 render
可以重绘整个东西,你会说:
suggestionsView.collection.reset(this.getSuggestions(query))
// ------------------------^^
刷新事物。
评论中的一些说明:模型不会生成'add'
事件,只有集合会触发这些事件。模型在其属性更改时触发 'change'
事件,集合在添加和删除模型时触发 'add'
和 'remove'
事件(分别) 从他们;集合也可以触发 'change'
事件,因为它们 forward all the events from their enclosed models :
Any event that is triggered on a model in a collection will also be triggered on the collection directly, for convenience.
因此,如果您想使用 Collection#set
,那么您需要在 View 中使用三个处理程序:
this.listenTo(this.collection, 'add', ...)
:一个新模型已添加到集合中,因此需要渲染它。this.listenTo(this.collection, 'remove', ...)
:模型已从集合中移除,因此移除它在 View 中的部分。this.listenTo(this.collection, 'change', ...)
:模型已更改,因此更新它的 View 部分。如果您只处理小型集合,那么 reset
可能不太有效。如果您的集合更大或 View 更改更昂贵,那么最好分别处理这三个事件。
无论如何,如果您正在使用 subview ,您将希望在父 View 中的某处维护它们的列表,以便您可以调用 remove
在他们身上,以确保事情得到妥善清理。如果您在从集合中删除模型时要销毁它们,您可以让 subview 绑定(bind)到它们模型的 'destroy'
事件并根据需要自行删除。
Catalog of Events可能值得回顾一下,看看什么时候触发了什么事件。
关于javascript - Backbone : How to update a collection view when collection changes?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20506543/
编辑:为了澄清,我想问的是:在什么情况下您会更喜欢一种语法而不是另一种语法? 有什么区别: .trigger('change') 和 .change() 两者都按预期工作。在任何情况下语法都会有所不同
这个问题在这里已经有了答案: Difference between .on('click') vs .click() (12 个答案) 关闭 6 年前。 有什么区别: $('选择器').change
我用的是Select2-4.0.0 和 $gameSelect.select2().on("change",function(e){....} 工作正常。 但是当我将它链接起来时('change')就
有一天在#haskell 上,有人提到了当字符串改变时字符串的类型应该如何改变的概念。这让我想起了我项目中的一些代码。它一直困扰着我,我说不清为什么。我现在推测,原因是我没有实现这个概念。这是下面的代
我使用了 .on("change") 事件函数,因为我的整个代码中有一部分是动态变化的。 .trigger("change") 在 .change() 中工作正常,但在 .on("change") 中
下面是一个非常简单的表单下拉列表设置。但是,on-change 事件拒绝触发...除非它更改为 ng-change。 这让我卡住了大约一个小时,因为我们在网站的其他地方使用了相同的设置(即模型属性/列
我有两个v-model 案例一: 这很好用 案例二: 即使改变 u1 也会触发 onDateChange(); 最佳答案 :change 绑定(bind)属性,如 v-bind:change=
我找到了 .and方法对于链接许多期望非常有用。 expect { click_button 'Update Boilerplate' @boilerplate_original.reload
出于合规性原因,我需要捕获所有数据库更改。我知道 Change Feed 存储此信息(并且我正在等待完全保真度来捕获删除)。目前,我一直在通过 Function 触发器读取 Change Feed 并
我添加了一个data-ng-change='getSubjectsClasswise(classBean.class_id);'上课标签,但主题未在主题 处加载标签。 一切看起来都很好,没有遇到问题
我有一组复选框,当您单击其中一个时,它们应该全部被选中。 当用户单击一个复选框时,它会检查以该类名称开头的所有其他复选框。我想要的是用户单击一个复选框,并且每次单击仅触发一次 $(".atpSelec
我在 Stack Overflow 上阅读了很多有关此问题的内容,并应用了所有建议的解决方案(getShell pack、布局、getparent 布局等...),但没有一个起作用。 我有一个带有文本
我想更改我的索引。我的数据框如下: partA = pd.DataFrame({'u1': 2, 'u2': 3, 'u3':4, 'u4':29, 'u5':4, 'u6':1, 'u7':323,
我有一个像这样的下拉菜单: Grade Year 旁边还有另一个下拉菜单: 3 4
这个问题已经有人问过,但我只停留在最基本的层面上。除了选择标记和尝试通过 jquery 捕获更改事件外,我没有向我的 html 添加任何内容。这是我的代码: $('#target').bin
我只是 Django 的新手几天。现在,当自定义表单中其他字段的值发生变化时,我需要同时更改一个字段中的值和表示形式。此时更改 MyModel 是受限。 我的应用程序/models.py: class
我正在使用 ListView 控件来显示一些数据行。有一个后台任务接收列表内容的外部更新。新收到的数据可能包含更少、更多或相同数量的项目,而且项目本身可能已更改。 ListView.ItemsSour
我在 android studio 中使用 git 插件。我的问题是当我提交更改列表(公开提交)时,但我在更改列表中的评论是错误的/丢失的,我想更改它。 问题: 有没有办法通过 AndroidStud
MyCustomObject * object=new MyCustomObject(); 假设我的许多类都使用了对象指针,但突然间我想在不更改地址的情况下更改指针的内容。 我认为 object =
我正在使用新的 KeyValue Observing。当变量发生变化时,我接到了我的观察者的电话,但 change struct 附带 newValue和 oldValue都为 nil ,所以它永远不
我是一名优秀的程序员,十分优秀!