我有一个包含数据的网格,包含在一个面板中,该面板还包含一个标题和一个较小的摘要网格。该面板具有适合的布局,因此标题和第一个网格(即摘要网格)显示得很好。但是有问题的网格的记录比屏幕上显示的要多,并且它的组件高度没有调整到面板的大小,面板的大小总是适合浏览器窗口的高度。
我想要的是网格组件的高度,就像面板一样,被调整到它的父级,这样网格体内的滚动条就会显示出来。
我的代码与此类似(initComponent 是 Ext.panel.Panel 的扩展):(此代码中的标题表示摘要网格)
initComponent: function (config) {
var config = {
border: false,
hidden: false,
hideMode: "display",
padding: '5',
layout: "fit"
}
Ext.apply(this, Ext.apply(this.initialConfig, config));
this.callParent(arguments);
title = Ext.create("Ext.panel.Panel", {
html: '<h2>title</h2>',
padding: '5',
border: false
});
// the stores for the grids are created here
var storeHdr = DataStoreFactory.CreateStore("GetHeaderP", DataStoreFactory.fieldsCollection.Default);
var storeBdy = DataStoreFactory.CreateStore("GetBodyP", DataStoreFactory.fieldsCollection.Default);
var grdHeader = Ext.create("Ext.grid.Panel", {
store: storeHdr,
columns: getHeaderColumns(),
columnLines: true,
autoHeight: false,
autoWidth: false,
enableHdMenu: false,
enableColumnMove: false,
enableColumnResize: false,
disableSelection: true,
trackMouseOver: false,
sortable: false
});
var grdBody = Ext.create("Ext.grid.Panel", {
id: id,
store: storeBdy,
columns: getBodyColumns(),
columnLines: true,
autoHeight: false,
autoWidth: false,
autoScroll: true,
scroll: "vertical",
enableColumnMove: false,
enableColumnResize: false,
enableHdMenu: false,
trackMouseOver: false,
disableSelection: true
});
},
var headerGridContainer = Ext.create("Ext.panel.Panel", {
layout: "fit",
border: false,
items: [grdHeader]
});
var bodyGridContainer = Ext.create("Ext.panel.Panel", {
layout: "fit",
border: false,
items: [grdBody]
});
this.add(title);
this.add(headerGridContainer);
this.add(bodyGridContainer);
storeHdr.load();
storeBdy.load();
this.doLayout();
}
我希望有人可以帮助我。提前致谢
编辑 - 截图它是如何以及它应该如何。实时数据被删除或抹去,因为它是私有的并且与问题无关。
就是这样
这是应该的