在EmberJS中,如何通过集合更新维护子组件状态?

时间:2016-04-15 00:38:06

标签: ember.js

很简单,是否有通过集合更新来持久化子组件状态的最佳实践。这是一个小提琴演示:

1.13 http://emberjs.jsbin.com/jazerepuqe/1/edit?html,js,output

2.4.4 https://ember-twiddle.com/6275ccd28b75c5f24d22c697049f291d?openFiles=components.parent-component.js%2Ctemplates.components.child-component.hbs

如何切换项目高度,添加新项目并让现有子项保持其状态?我是否需要编写自定义视图模型管理代码?这是在更新版本的Ember中解决的问题吗?

1 个答案:

答案 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
              );
            }
          }
    });