很简单,是否有通过集合更新来持久化子组件状态的最佳实践。这是一个小提琴演示:
1.13 http://emberjs.jsbin.com/jazerepuqe/1/edit?html,js,output
如何切换项目高度,添加新项目并让现有子项保持其状态?我是否需要编写自定义视图模型管理代码?这是在更新版本的Ember中解决的问题吗?
答案 0 :(得分:-1)
您的问题是,每次添加项时,都会返回一个静态heightToggle属性为false的新数组。如何将baseItems和newItems的结构更改为实际具有heightToggle属性。
baseItems: Ember.A([
Ember.Object.create({text: 'red', heightToggled: true}),
Ember.Object.create({text: 'blue', heightToggled: true}),
Ember.Object.create({text: 'green', heightToggled: true}),
]),
items: Ember.computed.map('baseItems', function(item) {
return Ember.Object.create({
text: item.text,
heightToggled: item.heightToggled
})
}),
actions: {
click() {
this.get('items').forEach(childItem => {
childItem.toggleProperty('heightToggled');
});
},
addItem() {
this.get('baseItems').pushObject(Ember.Object.create({
text: 'yellow' + Math.floor(Math.random() * 100000), // Random identifier
heightToggled: Boolean(Math.floor(Math.random() * 2))}) // Random booleans
);
}
}
});