如何更快地加载多个网格

Posted

技术标签:

【中文标题】如何更快地加载多个网格【英文标题】:How to load multiple grids faster 【发布时间】:2013-02-01 13:57:37 【问题描述】:

我有 4 个网格表。他们使用相同的模态。我不能使用同一个存储,因为每个网格都必须发送一个参数值才能从 db 获取数据。所以,发生的事情是我最终创建了 4 个不同的商店,然后当我加载我的应用程序时,它滞后了,因为它等待加载所有 4 个商店。这是我的网格.. 所以我还有 3 个这样的网格

this.grid1 =Ext.create('Ext.grid.Panel',
    title:'GridView App',        store: store,        loadMask:true,
    columns:[
        header:'Q1',            sortable:true, dataIndex:'Q1', flex:1,,
        header:'Q2',            sortable:true, dataIndex:'Q2', flex:1,,
        header:'Q3',            sortable:true, dataIndex:'Q3', flex:1,,
        header:'Q4',            sortable:true, dataIndex:'Q4', flex:1,

这是我的 store1... 同样,我还有 3 个这样的商店,每个都有参数 Q2、Q3、Q4

 var store1 =Ext.create('Ext.data.JsonStore',
    storeId:'myData',        scope:this,
    fields:[
        name:'Q1', type:'int',
        name:'Q2', type:'int',
        name:'Q3', type:'int',
        name:'Q4', type:'int'
   ],        
    sorters:[            property:'Q1',            direct:'ASC'],        
    proxy:            
          type:'ajax',            
          url:'GridView/writeRecord',            
          extraParams:  ID: Q1 ,            
          reader: newExt.data.JsonReader(                
               root:'myTable',              
               totalProperty:'count'
           )
       
 );

有没有比我现有的方式更快/更好的方式来实现它?

更新 -

第二次更新 -

这是我整个应用程序的布局...我的 rightcontainer 最初被禁用并包含实际的网格和表单,然后单击选项卡上的项目启用 rightcontainer 并加载所有网格。

Ext.define('ExtjsApp.app1.appPanel', 
extend: 'Ext.panel.Panel',
alias: 'widget.mypanel',
layout: 
    type: 'vbox',
    align: 'stretch'
,
scope: this,
titleAlign: 'center',
minWidth: 900,
bodyPadding: 10,
requires: [],
items: [],
constructor: function () 
    this.callParent(arguments);
    this.regForm = Ext.create('ExtjsApp.app1.RegForm', );

    leftTreeStore = Ext.create('Ext.data.TreeStore', 
        scope: this,
        storeId: 'leftTreeStore',
        fields: [
             name: 'text', type: 'string' ,
             name: 'dataId', type: 'string' ,
             name: 'listName', type: 'string' ,
             name: 'leaf', type: 'bool' 
        ],
        root:  expanded: true ,
        proxy: 
            type: 'ajax',
            url: 'app1/getRecords',
            extraParams:  organization: 'GOOGLE' ,
            reader:  type: 'json' 
        ,
        autoLoad: true,
        expanded: true,
        autoSync: true,
        listeners: 
        
    );

    allRecordsStore = Ext.create('Ext.data.TreeStore', 
        id: 'allRecordsStore',
        autoLoad: false,
        autoSync: false,
        scope: this,
        fields: [
             name: 'text', type: 'string' ,
             name: 'dataId', type: 'string' ,
             name: 'listName', type: 'string' ,
             name: 'leaf', type: 'bool' 
        ],
        root:  expanded: true ,
        proxy: 
            type: 'ajax',
            url: 'app1/getRecords',
            extraParams:  organization: 'GOOGLE' ,
            reader:  type: 'json' 
        
    );

    this.currentMonthsTree = Ext.create('Ext.tree.TreePanel', 
        scope: this,
        title: 'Current 12 Months',
        titleAlign: 'center',
        tabIndex: 0,
        height: 500,
        flex: 1,
        rootVisible: false,
        store: leftTreeStore,
        id: 'currentMonthsTree',
        useArrows: true,
        hideHeaders: true,
        columns: [
            
                xtype: 'treecolumn',
                id: 'ID',
                dataIndex: 'text',
                flex: 1
            
        ],
        viewConfig: 
            plugins: 
                ptype: 'treeviewdragdrop',
                enableDrop: false,
                appendOnly: false,
                enableDrag: false
            ,
            listeners: 
                itemclick: function (view, rec, item) 
                    if (rec.isLeaf()) 
                        alert('isLeaf');
                    
                    else if (!rec.isLeaf()) 
                        alert('isNotLeaf');
                    
                
            ,
            allowCopy: true,
            copy: true
        
    );

    this.currentMonthsTree.on('selectionchange', function (selected) 
        FnDisplayRecord(selected.selected.items[0]);
    );

    this.allRecordsTree = Ext.create('Ext.tree.TreePanel', 
        scope: this,
        title: 'All Records',
        titleAlign: 'center',
        flex: 1,
        tabIndex: 1,
        rootVisible: false,
        store: allRecordsStore,
        id: 'allRecordsTree',
        useArrows: true,
        hideHeaders: true,
        columns: [
            
                xtype: 'treecolumn',
                id: 'ID',
                dataIndex: 'text',
                flex: 1
            
        ],
        viewConfig: 
            plugins: 
                ptype: 'treeviewdragdrop',
                enableDrop: false,
                enableDrag: false,
                appendOnly: false
            ,
            listeners: 
                itemclick: function (view, rec, item) 
                    if (rec.isLeaf()) 
                        alert('isLeaf');
                    
                    else if (!rec.isLeaf()) 
                        alert('isNotLeaf');
                    
                
            ,
            allowCopy: true,
            copy: true
        
    );

    this.allRecordsTree.on('selectionchange', function (selected) 
        FnDisplayRecord(selected.selected.items[0]);
        //alert('Hello');
    );

    function FnClearValues() 
        //Clear All Values
        alert('ClearALLValues');
    

    function FnSetValues(myObj) 
        //I set all my form values using Ext.getCmp
        Ext.getCmp('Textl').setValue(myObj.Text1);
    


    function FnDisplayRecord(row) 
        if (row.get('leaf') == true) 
            console.log(row.data.dataId);
            var tempID = row.data.dataId;
            Ext.getCmp('rightContainer').setLoading(true, true);
            Ext.getCmp('requisitionPOGridPanel').store.loadData([], false);

            Ext.Ajax.request(
                method: 'GET',
                url: 'app1/getRecord',
                headers:  'Content-Type': 'application/json' ,
                dataType: 'json',
                params: 
                    ID: tempID
                ,
                success: function (response) 
                    Ext.getCmp('rightContainer').setLoading(false, false);
                    myObj = Ext.JSON.decode(response.responseText);
                    if (AsbestosObj.DateIssued != '') 
                        FnSetValues(AsbestosObj);
                        Ext.getCmp('GridPanel').store.load( params:  ID: tempID );
                        Ext.getCmp('Grid1').store.load( params:  ID: tempID, qID: 'Q01' );
                        Ext.getCmp('Grid2').store.load( params:  ID: tempID, qID: 'Q02' );
                        Ext.getCmp('Grid3').store.load( params:  ID: tempID, qID: 'Q03' );
                        Ext.getCmp('Grid4').store.load( params:  ID: tempID, qID: 'Q04' );
                    
                    else  FnClearValues(); 
                ,
                failure: function () 
                    Ext.Msg.alert('Message', 'Error');
                
            );
        
        else if (row.get('leaf') == false) 
            FnClearValues();
        
    

    this.rightContainer = Ext.create('Ext.form.Panel', 
        scope: this,
        id: 'rightContainer',
        layout: 
            type: 'vbox',
            align: 'stretch',
            pack: 'start'
        ,
        autoScroll: true,
        disabled: true,
        border: 1,
        flex: 1,
        items: [
            this.regForm
        ]
    );

    this.tabContainer = Ext.create('Ext.tab.Panel', 
        scope: this,
        activeTab: 0,
        flex: 0.5,
        id: 'tabContainer',
        layout:  type: 'vbox', align: 'stretch' ,
        plain: true,
        listeners: 
            tabchange: function (panel, newTab, oldTab) 
                Ext.getCmp('rightContainer').disable();
                FnClearValues();
                var getTabStat = this.getActiveTab();
                if (getTabStat.tabIndex == 0) 
                    Ext.getCmp('currentMonthsTree').store.load();
                
                else if (getTabStat.tabIndex == 1) 
                    Ext.getCmp('allRecordsTree').store.load();
                
            
        ,
        items: [
            this.currentMonthsTree, this.allRecordsTree
        ]
    );

    this.mainContainer = Ext.create('Ext.container.Container', 
        scope: this,
        bodyPadding: 10,
        title: 'MAIN',
        layout: 
            type: 'hbox',
            align: 'stretch'
        ,
        flex: 1,
        items: [
            this.tabContainer,
             xtype: 'splitter', width: 5, animate: true ,
            this.rightContainer
        ]
    );

    this.add(this.mainContainer);
,
loadingOn: function () 
    setTimeout(function ()  Ext.getCmp('currentMonthsTree').setLoading(true, true); , 100);

,

loadingOff: function () 
    setTimeout(function ()  Ext.getCmp('currentMonthsTree').setLoading(false, false); , 100);



);

【问题讨论】:

您的商店是否使用远程寻呼或过滤?如果他们不使用任何一个,我可以将其调整为更快。 @Reimius ...快得多?我很想听听你的方法。因为我们为一个真正的大型项目测试了几乎所有场景,即使是微优化也是相关的。唯一的变体是提供应用程序已经提供的所有数据,但这有其自身的缺点。 实际上 Reimius... 我根本不使用分页或排序,因为每个网格中的最大记录是 5。我绝对想看看你如何调整它。 【参考方案1】:

请参考我非常相似的 SO 问题:Combo box loads too slow

基本上,您需要像往常一样定义所有模型。

然后您需要将页面的所有商店定义为没有代理的数组商店,如下所示:

var myStore1 = Ext.create("Ext.data.ArrayStore", 
    model: "MyModel1",
    data:  []
);

var myStore2 = Ext.create("Ext.data.ArrayStore", 
    model: "MyModel1",
    data:  []
);

然后你会想要创建一个调用,无论你从哪里获取数据,你需要更改服务器以将所有数组输出到单个 JSON 对象中,就像这样,为了超级优化,让它们数组数组,这将是我期望从服务器得到的输出:


     grid_data_1: [...],
     grid_data_2: [...]

然后在您的网页上创建所有商店后,进行一次 ajax 调用以获取所有四个网格的数据:

Ext.Ajax.request(
    url: 'url',
    method: 'GET',
    params: 
        ...whatever you want
    ,

    success: function (response, opts) 
         var result = Ext.decode(response.responseText);
         myStore1.loadData(result.grid_data_1);
         myStore2.loadData(result.grid_data_2);
         ...
    ,

);

这将使其效率更高,您可能不需要在您的情况下使用数组数组,因为每个网格只有 5 行,但是将 4 个 ajax 调用优化为一个应该会产生很大的影响。

【讨论】:

@EagleFox 正确,通过这种方法,您可以将请求减少到一个。 +1 我直接使用它,因为它被引入 ExtJS 并且不再有这些问题。但根据 eagle 的最后一条评论,我认为他的问题取决于一些布局问题。 我也这么认为 sra.. 请看我的更新...你能看到我的布局有什么问题吗...我想如果我能弄清楚,它可能是 FnSetValue...应该我为表单设置值并在 itemclick 上调用 ajax 而不是“选择更改” 感谢 Reimius...这确实是我的布局...我没有调用函数“onchange”,而是将其重定向到 itemclick 事件...并且还在所有 4 个网格上实现了一个 ajax 调用。 .. 重大改进...感谢@sra 的提醒...你们太棒了【参考方案2】:

你不能在这里做更多的事情。我认为你可以做一些微曲,但我怀疑它们是否值得花时间来识别。如果您的应用执行以下操作,则说明您的操作完全正确;

加载完毕之前的时间 仅初始化所需的控制器和存储(检查每个请求) 显示主视图

一旦你的网格被渲染,它们就会触发加载操作,至少当它们有一个分页工具栏时。您可以更早地开始加载操作,这意味着在创建视图之前可能会给您一些毫秒,但我怀疑您是否可以节省更多时间。

这当然是基于现有的信息。

【讨论】:

同意,真的没有太多工作要做。我注意到 ArrayStore 往往比使用纯 JSON 数据更快,但这仍然是一个微优化。 我想我已经完成了所有这些 sra。我的网格仅在表单处于活动状态时加载...所以当我单击一个选项卡以激活我的表单时,它会滞后大约 3 秒...我什至创建了一个存储过程来更快地返回值,但没有改进 @EagleFox 这听起来不像是加载问题...请注意,即使商店未加载,网格也会呈现。然后它将简单地显示带有模糊主体的加载消息。所以我猜你这里有一个设计/布局问题导致了这个问题。 sra...在我的萤火虫上,我可以看到所有四家商店都在加载...请查看我的更新帖子 另外...确保在没有打开 firebug 的情况下测试页面。由于 extjs 代码库的深度,Firebug 有时可以通过 Extjs 真正减慢 firefox 的速度。如果您希望在调试过程中速度“正常”,请使用 chrome。

以上是关于如何更快地加载多个网格的主要内容,如果未能解决你的问题,请参考以下文章

如何更快地加载 MKMapView?

PHP 如何更快地执行这些检查/或更快地加载页面?

如何使用缓存使用 SfSafariView 或 WKWebView 更快地加载网站?

无法将本地存储的图像更快地加载到集合视图中。?

如何进行多线程以更快地将图像加载到 tableView

更快地加载firebase图像数据