2013-04-10 74 views
1

我是ExtJS的新手。ExtJs在同一頁上的兩個或多個網格

我在同一頁上有兩個網格。第一個網格有3列。第二隻。問題是,當第二個渲染時,它覆蓋了第一個網格的屬性。

例如,當我嘗試編輯第一個網格中的行時,它將從第二個網格獲取行中的寬度。

 
var $booleanArray = [ 
    ['denied', 'Denied'], 
    ['allowed', 'Allowed'] 
]; 

var myPageSize = 10; 

Ext.Loader.setConfig({ enabled: true }); 

Ext.require([ 
    'Ext.grid.*', 
    'Ext.data.*', 
    'Ext.util.*', 
    'Ext.state.*' 
]); 

Ext.onReady(function() { 

    Ext.define('CharacteristicModel', { 
     extend: 'Ext.data.Model', 
     fields: [ {name: 'name'}, {name: 'value'}, {name: 'order'} ], 
     validations: [ 
      { 
       type : 'length', 
       field: 'name', 
       min : 1 
      } 
     ] 
    }); 

    var characteristicsStore = new Ext.data.Store({ 
     proxy : { 
      model : 'CharacteristicModel', 
      type : 'rest', 
      api  : { 
       read : admin_path + '/getCharacteristics/1/', 
       create : admin_path + '/saveCharacteristics/1/', 
       update : admin_path + '/saveCharacteristics/1/', 
       destroy: admin_path + '/destroyCharacteristic/1/' 
      }, 
      reader : { 
       type   : 'json', 
       root   : 'data', 
       totalProperty: 'total_count' 
      }, 
      writer : { 
       type: 'json', 
       root: 'data' 
      }, 
      buffered: true 
     }, 
     listeners: { 
      read : function (response) { 
      }, 
      load : function (store) { 
      }, 
      write: function (store, operation) { 
       store.load(); 
      } 
     }, 
     pageSize : myPageSize, 
     autoLoad : { start: 0, limit: myPageSize }, 
     autoSync : true 
    }); 

    var rowEditing = Ext.create('Ext.grid.plugin.RowEditing'); 

    var characteristicsGrid = new Ext.grid.GridPanel({ 
     id   : 'characteristicsGrid', 
     renderTo : 'characteristics_grid_div_1', 
     store  : characteristicsStore, 
     width  : 480, 
     stateful : true, 
     stateId : 'characteristicsGrid', 
     title  : 'Grid "1"', 
     iconCls : 'icon-user', 
     listeners : { 
      itemdblclick: function (dv, row, item, index, e) { 
       dv.refresh(); 
       dv.getGridColumns()[0].setEditor({ 
        disabled: true, 
        editable: false 
       }); 

       if (row.data.id == 6 || row.data.id == 7) { 
        dv.getGridColumns()[1].setEditor({ 
         xtype  : 'combo', 
         store  : new Ext.data.ArrayStore({ 
          fields: ['abbr', 'action'], 
          data : $booleanArray 
         }), 
         displayField : 'action', 
         valueField : 'abbr', 
         mode   : 'local', 
         typeAhead : false, 
         triggerAction: 'all', 
         lazyRender : true, 
         emptyText : 'Select action' 
        }); 
       } 
       else if (row.data.id == 8 || row.data.id == 11) { 
        dv.getGridColumns()[1].setEditor({ 
         disabled: true, 
         editable: false 
        }); 
       } 
       else { 
        dv.getGridColumns()[1].setEditor({ 
         xtype: 'textfield' 
        }); 
       } 
      } 
     }, 
     columns : [ 
      { 
       id  : 'name', 
       text  : 'Account characteristic', 
       sortable : false, 
       width : 340, 
       fixed : true, 
       dataIndex: 'name' 
      }, 
      { 
       id  : 'value', 
       text  : 'Value', 
       sortable : false, 
       dataIndex: 'value', 
       width : 70, 
       fixed : true, 
       editor : { 
        xtype: 'textfield' 
       }, 
       renderer : function (value, field) { 
        if (field.record.data.id == 6 || field.record.data.id == 7) { 

         if ($booleanArray[0][0] != value) { 
          value = $booleanArray[1][1]; 
         } 
         else { 
          value = $booleanArray[0][1]; 
         } 
        } 
        return value; 
       } 
      }, 
      { 
       id  : 'order', 
       text  : 'Order', 
       sortable : false, 
       dataIndex: 'order', 
       width : 70, 
       fixed : true, 
       editor : { 
        xtype: 'textfield' 
       }, 
       renderer : function (value, field) { 
        return value; 
       } 
      } 
     ], 
     bbar  : Ext.create('Ext.PagingToolbar', { 
      store  : characteristicsStore, 
      displayInfo: true, 
      pageSize : myPageSize, 
      displayMsg : 'Show {0} - {1} из {2}', 
      emptyMsg : "0 rows" 
     }), 
     dockedItems: [ 
      { 
       xtype: 'toolbar', 
       items: [ 
        { 
         text : 'Add', 
         iconCls: 'icon-add', 
         handler: function() { 
          var grid_colums = rowEditing.cmp.getSelectionModel().view.getGridColumns(); 
          grid_colums[0].setEditor({ 
           xtype  : 'combo', 
           store  : new Ext.data.ArrayStore({ 
            fields: ['id', 'name'], 
            data : $characteristics 
           }), 
           displayField : 'name', 
           valueField : 'id', 
           mode   : 'local', 
           typeAhead : false, 
           triggerAction: 'all', 
           lazyRender : true, 
           emptyText : 'Select action' 
          }); 
          grid_colums[1].setEditor({ 
           xtype: 'textfield' 
          }); 
          // empty record 
          //characteristicsStore.autoSync = false; 
          characteristicsStore.insert(0, new CharacteristicModel()); 
          rowEditing.startEdit(0, 0); 
          //characteristicsStore.autoSync = true; 
         } 
        }, 
        '-', 
        { 
         itemId : 'delete', 
         text : 'Delete', 
         iconCls : 'icon-delete', 
         disabled: true, 
         handler : function() { 
          var selection = characteristicsGrid.getView().getSelectionModel().getSelection()[0]; 
          if (selection) { 
           characteristicsStore.remove(selection); 
          } 
         } 
        } 
       ] 
      } 
     ], 
     plugins : [rowEditing] 
    }); 

    characteristicsGrid.getSelectionModel().on('selectionchange', function (selModel, selections) { 
     characteristicsGrid.down('#delete').setDisabled(selections.length === 0); 
    }); 

}); 


Ext.onReady(function() { 

    Ext.define('AdvantagesModel', { 
     extend: 'Ext.data.Model', 
     fields: [ 
      {name: 'name'} 
     ] 
    }); 

    // setup the state provider, all state information will be saved to a cookie 
    //Ext.state.Manager.setProvider(Ext.create('Ext.state.CookieProvider')); 

    var advantagesStore = new Ext.data.Store({ 
     idProperty: 'AdvantagesModel', 
     proxy : { 
      model : 'AdvantagesModel', 
      type : 'rest', 
      api  : { 
       read : admin_path + '/getAdvantages/1/', 
       create : admin_path + '/saveAdvantages/1/', 
       destroy: admin_path + '/destroyAdvantages/1/' 
      }, 
      reader : { 
       type   : 'json', 
       root   : 'data', 
       totalProperty: 'totalCount' 
      }, 
      writer : { 
       type: 'json', 
       root: 'data' 
      }, 
      buffered: true 
     }, 
     listeners: { 
      read : function (response) { 
      }, 
      load : function (store) { 
      }, 
      write: function (store, operation) { 
       store.load(); 
      } 
     }, 
     pageSize : myPageSize, 
     autoLoad : { start: 0, limit: myPageSize }, 
     autoSync : true 
    }); 

    var rowEditing = Ext.create('Ext.grid.plugin.RowEditing'); 

    var advantagesGrid = new Ext.grid.GridPanel({ 
     id   : 'advantagesGrid', 
     renderTo : 'advantages_grid_div_1', 
     store  : advantagesStore, 
     width  : 482, 
     height  : 355, 
     stateful : true, 
     stateId : 'advantagesGrid', 
     title  : 'Grid 2', 
     iconCls : 'icon-user', 
     listeners : { 
      beforeedit: function (dv, row, item) { 
       //advantagesGrid.getView().refresh(); 
       if (row.record.raw) 
       { 
        return false; 
       } 
      } 
     }, 
     columns : [ 
      { 
       id  : 'name', 
       text  : 'Advantages', 
       sortable : false, 
       dataIndex: 'name', 
       width : 480 
      } 
     ], 
     bbar  : Ext.create('Ext.PagingToolbar', { 
      store  : advantagesStore, 
      displayInfo: true, 
      pageSize : myPageSize, 
      displayMsg : 'Show {0} - {1} из {2}', 
      emptyMsg : "0 rows" 
     }), 
     dockedItems: [ 
      { 
       xtype: 'toolbar', 
       items: [ 
        { 
         text : 'Add', 
         iconCls: 'icon-add', 
         handler: function() { 
          var grid_colums = rowEditing.cmp.getSelectionModel().view.getGridColumns(); 
          grid_colums[0].setEditor({ 
           xtype  : 'combo', 
           store  : new Ext.data.ArrayStore({ 
            fields: ['id', 'name'], 
            data : $advantages 
           }), 
           displayField : 'name', 
           valueField : 'id', 
           mode   : 'local', 
           typeAhead : false, 
           triggerAction: 'all', 
           lazyRender : true, 
           emptyText : 'Select action' 
          }); 
          // empty record 
          advantagesStore.autoSync = false; 
          advantagesStore.insert(0, new AdvantagesModel()); 
          rowEditing.startEdit(0, 0); 
          advantagesStore.autoSync = true; 
         } 
        }, 
        '-', 
        { 
         itemId : 'delete', 
         text : 'Delete', 
         iconCls : 'icon-delete', 
         disabled: true, 
         handler : function() { 
          var selection = advantagesGrid.getView().getSelectionModel().getSelection()[0]; 
          if (selection) { 
           advantagesStore.remove(selection); 
          } 
         } 
        } 
       ] 
      } 
     ], 
     plugins : [rowEditing] 
    }); 

    advantagesGrid.getSelectionModel().on('selectionchange', function (selModel, selections) { 
     advantagesGrid.down('#delete').setDisabled(selections.length === 0); 
    }); 

}); 

回答

2

的替代品有你的兩個電網的id列識別不同的是有兩個不同的實例/的Ext.grid.plugin的對象.RowEditing類,如果您在同一頁面上有兩個可編輯的網格。很多時候,擁有相同的ID很重要。

var rowEditing = Ext.create('Ext.grid.plugin.RowEditing'); 

var rowEditing2 = Ext.create('Ext.grid.plugin.RowEditing'); 

plugins : [rowEditing] 

plugins : [rowEditing2] 
0

發現問題。

columns : [ 
     { 
      id  : 'name', 

列ID必須是不同的,即使他們是在diferent網格

+3

使用itemId而不是id。它的範圍是對象 – 2013-04-10 19:16:18

相關問題