编程语言
首页 > 编程语言> > javascript-Sencha Extjs-如何通过一次设置记录中的数据来更新网格?

javascript-Sencha Extjs-如何通过一次设置记录中的数据来更新网格?

作者:互联网

我有一个包含1000多个行(用户)和一个检查列的网格,该网格用于将每个用户链接到另一个特定实例(例如一组用户).
我实现了一个“全选”按钮,它可以执行以下操作:

   var items = view.store.data.items;
    var dataIndex = 'dataIndexOfCheckColumn';
    var check = true;
    //view.store.suspendEvents();
    for (var i = 0; i < items.length; i++)
    {
        var record = view.store.getAt(i),
        record.set(dataIndex, check);
        this.fireEvent('checkchange', this, i, check, record);
    }
    //view.store.resumeEvents();

这种方法的问题在于,每个“记录”集都会触发某些事件(验证,取消联接等),并且对于1000条记录来说太多了. Chrome在几乎一秒钟的时间内完成了此操作,但是IE(9,10)对于“ …”来说是一个痛苦.将近2分钟.

还有另一种方法吗?我正在考虑在商店上挂起事件,然后恢复它们并与网格同步商店,但是我在文档中找不到如何实现这样的事情.

我正在使用ExtJs版本4.0.1

解决方法:

我设法通过暂停和恢复事件来解决此问题,然后刷新视图.如果有人需要这个:

var items = view.store.data.items
    var dataIndex = 'dataIndexOfCheckColumn';
    var check = true;
    /*suspend events to block firing the events on setting record values
    then resume and refresh the view
    */
    view.store.suspendEvents();
            for (var i = 0; i < items.length; i++)
            {
                var record = view.store.getAt(i);
                record.set(dataIndex, check);
                this.fireEvent('checkchange', this, i, check, record);
            }
            view.store.resumeEvents();
            view.getView().refresh();

标签:extjs,updates,grid,multiple-records,javascript
来源: https://codeday.me/bug/20191122/2061695.html