winform下拉列表控件 winform数据可视化控件

在Winform开发中 。我们往往除了常规的单表信息录入外 。有时候设计到多个主从表的数据显示、编辑等界面 。单表的信息一般就是控件和对象实体一一对应 。然后调用API保存即可 。主从表就需要另外特殊处理 。本随笔介绍如何快速实现主从表编辑界面的处理 。结合GridControl控件的GridView控件对象 。实现数据在列表中的实时编辑 。非常方便 。
一、主从表的界面设计及展示主从表一般涉及两个以上的表 。一个是主表 。其他的是从表的 。在实际情况下 。一般包含两个表较多 。我们这里以两个表的主从表关系进行分析处理 。
例如我们建立两个报销申请单表关系如下所示 。
【winform下拉列表控件 winform数据可视化控件】

winform下拉列表控件 winform数据可视化控件

文章插图

winform下拉列表控件 winform数据可视化控件

文章插图
对于报销的主从表信息 。我们可以在列表中进行展示 。如下界面所示 。分为两部分:一部分是主表信息 。一部分是从表信息 。单击主表信息后 。显示对应从表的列表信息 。
winform下拉列表控件 winform数据可视化控件

文章插图

winform下拉列表控件 winform数据可视化控件

文章插图
那么我们新增一条主表记录的时候 。那么可以弹出一个新的界面进行数据的维护处理 。方便我们录入主从表的信息 。界面如下所示 。
winform下拉列表控件 winform数据可视化控件

文章插图

winform下拉列表控件 winform数据可视化控件

文章插图
上面界面包括了主表信息 。以及从表的信息(在GridView中实时录入)两部分 。这样填写后统一进行提交处理 。
二、主从表编辑界面的处理这里主要介绍一下主从表的编辑界面处理 。也就是上面这个界面的实现处理 。
winform下拉列表控件 winform数据可视化控件

文章插图

winform下拉列表控件 winform数据可视化控件

文章插图
其中初始化GridView的代码如下所示 。
///<summary>///初始化明细表的GridView数据显示///</summary>privatevoidInitDetailGrid(){//初始清空列this.gridView1.Columns.Clear();//设置部分列隐藏this.gridView1.CreateColumn("ID","编号").Visible=false;this.gridView1.CreateColumn("Header_ID","主表编号").Visible=false;this.gridView1.CreateColumn("apply_ID","申请单编号").Visible=false;//添加下拉列表列 。并绑定数据源this.gridView1.CreateColumn("FeeType","费用类型",100).CreateComboBox().BindDictItems("费用类型");//创建日期列并指定格式varOccurTime=this.gridView1.CreateColumn("OccurTime","发生时间",120).CreateDateEdit();OccurTime.EditMask="yyyy-MM-ddHH:mm";OccurTime.DisplayFormat.FormatString="yyyy-MM-ddHH:mm";//创建数值列this.gridView1.CreateColumn("FeeAmount","费用金额").CreateSpinEdit();//创建备注列this.gridView1.CreateColumn("FeeDescription","费用说明",200).CreateMemoEdit();//初始化GridView 。可以新增列this.gridView1.InitGridView(GridType.NewItem,false,EditorShowMode.MouseDownFocused,"");//转义列内容显示this.gridView1.CustomColumnDisplayText+=newCustomColumnDisplayTextEventHandler(gridView1_CustomColumnDisplayText);//处理单元格的样式this.gridView1.RowCellStyle+=newRowCellStyleEventHandler(gridView1_RowCellStyle);//不允许头部排序this.gridView1.OptionsCustomization.AllowSort=false;//绘制序号this.gridView1.CustomDrawRowIndicator+=(s,e)=>{if(e.Info.IsRowIndicator&&e.RowHandle>=0){e.Info.DisplayText=(e.RowHandle+1).ToString();}};//对输入单元格进行非空校验this.gridView1.ValidateRow+=delegate(objectsender,ValidateRowEventArgse){varresult=gridControl1.ValidateRowNull(e,newstring[]{"FeeType"});};//新增行的内容初始化this.gridView1.InitNewRow+=(s,e)=>{gridView1.SetRowCellValue(e.RowHandle,"ID",Guid.NewGuid().ToString());gridView1.SetRowCellValue(e.RowHandle,"Header_ID",tempInfo.ID);gridView1.SetRowCellValue(e.RowHandle,"Apply_ID",tempInfo.Apply_ID);gridView1.SetRowCellValue(e.RowHandle,"OccurTime",DateTime.Now);};}voidgridView1_RowCellStyle(objectsender,DevExpress.XtraGrid.Views.Grid.RowCellStyleEventArgse){GridViewgridView=this.gridView1;if(e.Column.FieldName=="FeeAmount"){e.Appearance.BackColor=Color.Green;e.Appearance.BackColor2=Color.LightCyan;}}voidgridView1_CustomColumnDisplayText(objectsender,DevExpress.XtraGrid.Views.Base.CustomColumnDisplayTextEventArgse){stringcolumnName=e.Column.FieldName;if(e.Column.ColumnType==typeof(DateTime)){if(e.Value!=null){if(e.Value=https://www.wangchuang8.com/=DBNull.Value||Convert.ToDateTime(e.Value)

推荐阅读