如何观察向数组添加元素

时间:2012-02-28 17:12:29

标签: ember.js

我想观察向数组添加元素。 以下是测试程序。

<!-- library load -->
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js"></script>
<script>!window.jQuery && document.write(unescape('%3Cscript src="js/libs/jquery-1.6.1.min.js"%3E%3C/script%3E'))</script>
<script src="http://cloud.github.com/downloads/emberjs/ember.js/ember-0.9.5.min.js"></script>

<script type="text/x-handlebars">
  {{#each App.ArrayController.array}}
    {{foo}}
  {{/each}}
  <button onclick="App.ArrayController.addElement();">add</button>
</script>
<script type="text/javascript">
  var App = Em.Application.create();
  App.ArrayController = Em.Object.create({
    array: [{foo:1}, {foo:2}, {foo:3}],
    addElement: function() {
      this.array.pushObject({foo:4});
    },
    elementAdded: function() {
      alert('ok'); // not invoked...
    }.observes('array')
  })
</script>  

但是当调用addElement时,不会调用elementAdded ... 如何观察添加元素?

3 个答案:

答案 0 :(得分:24)

使用observes('array。@ each')代替。 jsfiddle代码是here

答案 1 :(得分:6)

您可以使用Ember.ArrayController并覆盖arrayDidChange函数 并且可以选择其他方法。

<!-- library load -->
<script type="text/x-handlebars">
  {{#each App.ArrayController.array}}
    {{foo}}
  {{/each}}
  <button onclick="App.ArrayController.addElement();">add</button>
</script>
<script type="text/javascript">
  var App = Em.Application.create();
  App.arrayController = Ember.ArrayController.create({
    content: [{foo:1}, {foo:2}, {foo:3}],
    addElement: function() {
      console.log(this);
      var array = this.get('content')
      array.pushObject({foo:4});
      // this.set('array', array);
    },
    elementAdded: function() {
      console.log('ok'); // not invoked...
    }.observes('array'),

    arrayDidChange: function(item, idx, removedCnt, addedCnt) {
      this.elementAdded();
      this._super(item, idx, removedCnt, addedCnt);
    }
  });
</script>

您可以使用Observers

答案 2 :(得分:3)

Check out this fiddle了解如何使用ArrayController确切地知道在数组中添加或删除了哪些对象。