ArrayController排序后,Ember视图不会更新

时间:2013-09-20 19:46:54

标签: ember.js

我有一个绑定到Ember选择视图的Ember数组控制器,如果用户选择,它将被用户排序。一旦所有内容都通过我的排序,我使用现在排序的数组重置数组,视图不会改变,但如果我循环遍历我刚设置的数组,它会显示它已排序。因此,我相信视图不会使用阵列控制器进行更新。我正在查看其他类似问题的帖子,但是没有一个解决方案适合我。

dmp: Ember.ArrayController.create(),
tempArray: new Array(),

sort: function() {
        debugger;
        var self = this;
        var textA, textB, i, t, pos, temp;
        this.set('tempArray',  self.dmp.get('content'));
        var nxt;
        for(t = 0; t < (self.get('tempArray').length) - 1; t++) {
            nxt = this.get('tempArray')[t];
            for(i = t; i < self.get('tempArray').length; i++) {
                if(self.get('tempArray')[i].name.toUpperCase() <= nxt.name.toUpperCase()) {
                    nxt = self.get('tempArray')[i];
                    pos = i;
                }
            }
            temp = self.get('tempArray')[t];
            self.get('tempArray')[t] = nxt;
            self.get('tempArray')[pos] = temp;
        }
        //App.defRouteSearch.dmpName.set('content', self.get('tempArray'));
        //App.defRouteSearch.dmp.set('content', self.get('tempArray'));
        self.setArray();
    }, 

setArray: function() {
        debugger;
        var a = 0, b = 1;
        var self = this;
        while(a < this.get('tempArray').length) {
            self.get('dmp').toArray[b] = self.get('tempArray')[a];
            a++;
            b++;
        }
    }

我将所有内容切换到普通的js数组,因为与数组控制器相比,操作数据的速度更快,我填写其他6个数组时,我会在其余代码中执行此操作,这样就不会造成任何问题。注释代码是我在设置数组之前所做的。 谢谢你的帮助。

2 个答案:

答案 0 :(得分:2)

无需做所有这些。这应该可以解决问题:

App.MyArrayController = Ember.ArrayController.create({
  content: songs,
  sortProperties: ['name'],
  sortAscending: true
});

答案 1 :(得分:0)

过了一段时间我才能让它上班。现在是我的排序

sortName: function() {
        var self = this;
        var i, t, pos, temp;
        this.set('tempArray', new Array());
        this.set('tempArray',  self.dmp.get('content'));
        var nxt;
        for(t = 0; t < (self.get('tempArray').length) - 1; t++) {
            nxt = this.get('tempArray')[t];
            for(i = t; i < self.get('tempArray').length; i++) {
                if(self.get('tempArray')[i].name.toUpperCase() <= nxt.name.toUpperCase()) {
                    nxt = self.get('tempArray')[i];
                    pos = i;
                }
            }
            temp = self.get('tempArray')[t];
            self.get('tempArray')[t] = nxt;
            self.get('tempArray')[pos] = temp;
        }
        self.dmp.set('content', self.tempArray.clone());
    }, 

Array.prototype.clone = function () {
    var newObj = [];
    for (i in this) {
        if (this[i]) {
            if ($.isPlainObject(this[i])) {
                newObj[i] = $.extend(true, {}, this[i]);
            }
            else if ($.isArray(this[i])) {
                this[i].clone();
            }
            else {
                newObj[i] = this[i];
            }
        }        
    }
    return newObj;
};

我不完全确定它为什么会起作用但确实如此。我能想到的一点点推理是,在js中复制数组时,它只被引用而不是实际复制。但是,由于引用的数组被修改,我最后不需要clone()。如果我错了,请随意纠正我。