用嵌套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的主从表显示的主要内容,如果未能解决你的问题,请参考以下文章

easyui 子表格再嵌套一层表格,该怎样实现?

easyui主从表实现

easyui中datagrid常见功能

WPF DataGrid 表格样式怎么实现

在运行时将新表重新加载/替换到 WPF DataGrid 中

WPF DataGrid 绑定到List集合