我在网格中使用了kendo列菜单。如果我取消选中columnmenu中的项目,则列宽度不能正确占据整个宽度。 任何人都可以帮我解决这个问题。
var grid = $("#grid").kendoGrid({
dataSource: {
data : createRandomData(100),
pageSize : 10,
schema: {
model: {
fields: {
Id : { type: 'number' },
FirstName: { type: 'string' },
LastName : { type: 'string' },
City : { type: 'string' }
}
}
}
},
pageable : true,
columnMenu: true,
columns : [
{ field: "FirstName", width: 90, title: "First Name" },
{ field: "LastName", width: 90, title: "Last Name" },
{ field: "City", width: 100 }
],
dataBound: function () {
$(".k-header-column-menu").kendoTooltip({
content: "column menu"
});
}
}).data("kendoGrid");
检查这个小提琴
答案 0 :(得分:2)
问题是因为为每列指定了width
。当网格最初加载时,它会忽略宽度,并将其用作总数的一部分。当您使用列菜单时,它会强制您说出的宽度。
根据您要实现的目标,只需从列定义中删除width
,或确保Grid
具有所需的宽度。
在此处调整列的大小以使用网格的全宽度的示例http://jsfiddle.net/OnaBai/JCSGz/2/
如果你想要的是调整表的大小以保持每个列的宽度,你应该:
CSS:
#grid {
width: 300px
}
JavaScript的:
var grid = $("#grid").kendoGrid({
dataSource: {
data : createRandomData(100),
pageSize : 10,
schema: {
model: {
fields: {
Id : { type: 'number' },
FirstName: { type: 'string' },
LastName : { type: 'string' },
City : { type: 'string' }
}
}
}
},
pageable : true,
columnMenu: true,
columnHide: function (e) {
this.wrapper.width(grid.wrapper.width() - e.column.width);
},
columnShow: function (e) {
this.wrapper.width(grid.wrapper.width() + e.column.width);
},
columns : [
{ field: "FirstName", width: 100, title: "First Name" },
{ field: "LastName", width: 50, title: "Last Name" },
{ field: "City", width: 150 }
],
dataBound: function () {
$(".k-header-column-menu").kendoTooltip({
content: "column menu"
});
}
}).data("kendoGrid");
在JSFiddle中运行示例:http://jsfiddle.net/OnaBai/JCSGz/4/
答案 1 :(得分:0)
我遇到了同样的问题,我在this link
上找到了解决方案function loadColumnState(columnStateKey: string, realGrid): void
{
var colState = JSON.parse($.jStorage.get(columnStateKey));
if(colState && colState.length > 0)
{
var visibleIndex = -1;
for (var i = 0; i < colState.length; i++)
{
var column = colState[i];
// 1. Set correct order first as visibility and width both depend on this.
var existingIndex = -1;
if (typeof column.field !== 'undefined')
{
existingIndex = findFieldIndex(realGrid, column.field);
}
else if (typeof column.commandName !== 'undefined')
{
existingIndex = findCommandIndex(realGrid, column.commandName);
}
if (existingIndex > -1 && existingIndex != i) // Different index
{ // Need to reorder
realGrid.reorderColumn(i, realGrid.columns[existingIndex]);
}
// 2. Set visibility state
var isHidden = (typeof column.hidden === 'undefined') ? false : column.hidden;
if (isHidden)
{
realGrid.hideColumn(i);
}
else
{
realGrid.showColumn(i);
++visibleIndex;
}
// 3. Set width
var width = (typeof column.width === 'undefined') ? null : column.width;
if(width != null)
{
realGrid.columns[i].width = width; // This sets value, whilst rest redraws
realGrid.thead.prev().find('col:eq(' + visibleIndex + ')').width(width);
realGrid.table.find('>colgroup col:eq(' + visibleIndex + ')').width(width);
}
}
}
}
答案 2 :(得分:0)
尝试这些方式以使用不同的选项(%,px,auto)设置列宽:
@(Html.Kendo().Grid<TrainingViewModel>()
.Name("Grid")
.Columns(columns =>
{
columns.Bound(t => t.Name).Title("Training Name").Width("%100"); //set width in %
columns.Bound(t => t.Date).Title("Date").Width("150px"); //set width in pixel
columns.Bound(t => t.CityName).Title("City"); //set width auto (no width property)
})
)
希望这会有所帮助......