用嵌套List实现DataGrid的主从表显示
Posted mol1995
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用嵌套List实现DataGrid的主从表显示相关的知识,希望对你有一定的参考价值。
//首先构造嵌套List,也就是一个list在另一个list中充当成员
//如:referModels 在res中充当成员
var res = totalAffectedMedels.Select(c => new
{
TIME_SLICE_ID = c.curModel.TIME_SLICE_ID,
referModels = c.referModels == null ? null : c.referModels.Select(n => new
{
数据类型 = n.TABLE_INFO,
名称 = n.NAME,
识别 = n.DESIGNATOR,
数量 = n.mCount
}).ToList(),
任务操作 = c.operType == CmmDb.DbOperation.Add ? "添加" :"",
数据类型 = c.curModel.TABLE_INFO,
名称 = c.curModel.NAME,
识别 = c.curModel.DESIGNATOR
}).ToList();
//最简单的方法直接将此list绑定到gdc的DataSource就能自动出现主从界面,不用在界面上做任何设置,如
//要显示隐藏哪些列完全通过上面的自定义List实现
//子表的标签会自动为referModels
CmmFrm.BestFitGridViewListWidth(gdc_TaskCancel, res, 1);
//如果要仅有个别列要隐藏,添加绑定事件MasterRowExpanded,在点击行头的+时触发
private void gdv_TaskCancel_MasterRowExpanded(object sender, DevExpress.XtraGrid.Views.Grid.CustomMasterRowEventArgs e)
{
GridView gridViewMaster = sender as GridView;
GridView gridViewDetail = gridViewMaster.GetDetailView(e.RowHandle, e.RelationIndex) as GridView;
if (gridViewDetail.IsNotNull())
{
gridViewDetail.BeginUpdate();
gridViewDetail.Columns["TIME_SLICE_ID"].Visible = false;
gridViewDetail.Columns["TIME_SLICE_ID"].OptionsColumn.ShowInCustomizationForm = false;
gridViewDetail.EndUpdate();
}
}
//一般的做法是在gdv中添加Level视图,点击右键修改视图名称为子List名称,referModels,可绑定子表。所有子表列都能自动显示。
//也可以在界面中添加字段
以上是关于用嵌套List实现DataGrid的主从表显示的主要内容,如果未能解决你的问题,请参考以下文章