百摩网
当前位置: 首页 生活百科

winform下拉框控件(讲解winform下拉框绑定数据)

时间:2023-05-25 作者: 小编 阅读量: 5 栏目名: 生活百科

在Winform开发中,我们往往除了常规的单表信息录入外,有时候设计到多个主从表的数据显示、编辑等界面,单表的信息一般就是控件和对象实体一一对应,然后调用API保存即可,主从表就需要另外特殊处理,本随笔介绍如何快速实现主从表编辑界面的处理,结合GridControl控件的GridView控件对象,实现数据在列表中的实时编辑,非常方便。上面界面包括了主表信息,以及从表的信息两部分,这样填写后统一进行提交处理。其中初始化GridView的代码如下所示。

在Winform开发中,我们往往除了常规的单表信息录入外,有时候设计到多个主从表的数据显示、编辑等界面,单表的信息一般就是控件和对象实体一一对应,然后调用API保存即可,主从表就需要另外特殊处理,本随笔介绍如何快速实现主从表编辑界面的处理,结合GridControl控件的GridView控件对象,实现数据在列表中的实时编辑,非常方便。

一、主从表的界面设计及展示

主从表一般涉及两个以上的表,一个是主表,其他的是从表的,在实际情况下,一般包含两个表较多,我们这里以两个表的主从表关系进行分析处理。

例如我们建立两个报销申请单表关系如下所示。

对于报销的主从表信息,我们可以在列表中进行展示,如下界面所示,分为两部分:一部分是主表信息,一部分是从表信息,单击主表信息后,显示对应从表的列表信息。

那么我们新增一条主表记录的时候,那么可以弹出一个新的界面进行数据的维护处理,方便我们录入主从表的信息,界面如下所示。

上面界面包括了主表信息,以及从表的信息(在GridView中实时录入)两部分,这样填写后统一进行提交处理。

二、主从表编辑界面的处理

这里主要介绍一下主从表的编辑界面处理,也就是上面这个界面的实现处理。

其中初始化GridView的代码如下所示。

/// <summary>/// 初始化明细表的GridView数据显示/// </summary>private void InitDetailGrid(){//初始清空列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("费用类型");//创建日期列并指定格式var OccurTime = this.gridView1.CreateColumn("OccurTime", "发生时间", 120).CreateDateEdit();OccurTime.EditMask = "yyyy-MM-dd HH:mm";OccurTime.DisplayFormat.FormatString = "yyyy-MM-dd HH:mm";//创建数值列this.gridView1.CreateColumn("FeeAmount", "费用金额").CreateSpinEdit();//创建备注列this.gridView1.CreateColumn("FeeDescription", "费用说明", 200).CreateMemoEdit();//初始化GridView,可以新增列this.gridView1.InitGridView(GridType.NewItem, false, EditorShowMode.MouseDownFocused, ");//转义列内容显示this.gridView1.CustomColumnDisplayText += new CustomColumnDisplayTextEventHandler(gridView1_CustomColumnDisplayText);//处理单元格的样式this.gridView1.RowCellStyle += new RowCellStyleEventHandler(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(object sender, ValidateRowEventArgs e){var result = gridControl1.ValidateRowNull(e, new string[]{"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);};}void gridView1_RowCellStyle(object sender, DevExpress.XtraGrid.Views.Grid.RowCellStyleEventArgs e){GridView gridView = this.gridView1;if (e.Column.FieldName == "FeeAmount"){e.Appearance.BackColor = Color.Green;e.Appearance.BackColor2 = Color.LightCyan;}}void gridView1_CustomColumnDisplayText(object sender, DevExpress.XtraGrid.Views.Base.CustomColumnDisplayTextEventArgs e){string columnName = e.Column.FieldName;if (e.Column.ColumnType == typeof(DateTime)){if (e.Value != null){if (e.Value == DBNull.Value || Convert.ToDateTime(e.Value) <= Convert.ToDateTime("1900-1-1")){e.DisplayText = ";}else{e.DisplayText = Convert.ToDateTime(e.Value).ToString("yyyy-MM-dd HH:mm");//yyyy-MM-dd}}}}

上面代码都有详细的备注,主要就是我们根据数据库表的关系,创建对应显示的字段即可,其中有需要隐藏的那么就不要显示(方便获取对应的值)

//设置部分列隐藏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("费用类型");

如果是一些特殊的输入需要设置格式显示或者掩码,那么如下所示

//创建日期列并指定格式var OccurTime = this.gridView1.CreateColumn("OccurTime", "发生时间", 120).CreateDateEdit();OccurTime.EditMask = "yyyy-MM-dd HH:mm";OccurTime.DisplayFormat.FormatString = "yyyy-MM-dd HH:mm";

另外有一个值得注意的就是我们新增一行从表记录的时候,需要记录一些主表的属性,这样的话,我们就是在行初始化的时候,赋值给从表的隐藏列即可。

//新增行的内容初始化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);};

在界面中如果我们需要显示主表的信息,那么就根据条件获取对应的主表记录对象,然后显示给界面控件即可。

/// <summary>/// 显示常规的对象内容/// </summary>/// <param name="info"></param>private void DisplayInfo(ReimbursementInfo info){tempInfo = info;//重新给临时对象赋值,使之指向存在的记录对象txtCategory.Text = info.Category;txtReason.Text = info.Reason;txtTotalAmount.Value = info.TotalAmount;txtNote.Text = info.Note;}

而保存的时候,我们把界面内容重新赋值给对应的主表对象。

/// <summary>/// 编辑或者保存状态下取值函数/// </summary>/// <param name="info"></param>private void SetInfo(ReimbursementInfo info){info.Category = txtCategory.Text;info.Reason = txtReason.Text;info.TotalAmount = txtTotalAmount.Value;info.Note = txtNote.Text;info.ApplyDate = DateTime.Now;info.ApplyDept = base.LoginUserInfo.DeptId;info.CurrentLoginUserId = base.LoginUserInfo.ID;}

而我们需要获取GridView明细输入的时候,就通过一个函数遍历获取GridView的行记录,转换为相应的对象即可,如下所示。

/// <summary>/// 获取明细列表/// </summary>/// <returns></returns>private List<ReimbursementDetailInfo> GetDetailList(){var list = new List<ReimbursementDetailInfo>();for (int i = 0; i < this.gridView1.RowCount; i++){var detailInfo = gridView1.GetRow(i) as ReimbursementDetailInfo;if (detailInfo != null){list.Add(detailInfo);}}return list;}

这样处理完这些信息后,我们就可以在主表保存的时候,同时保存明细表信息即可。

/// <summary>/// 新增状态下的数据保存/// </summary>/// <returns></returns>public override bool SaveAddNew(){ReimbursementInfo info = tempInfo;//必须使用存在的局部变量,因为部分信息可能被附件使用SetInfo(info);info.Creator = base.LoginUserInfo.ID;info.CreateTime = DateTime.Now;try{#region 新增数据bool succeed = BLLFactory<Reimbursement>.Instance.Insert(info);if (succeed){//可添加其他关联操作var list = GetDetailList();foreach(var detailInfo in list){BLLFactory<ReimbursementDetail>.Instance.InsertUpdate(detailInfo, detailInfo.ID);}return true;}#endregion}catch (Exception ex){LogTextHelper.Error(ex);MessageDxUtil.ShowError(ex.Message);}return false;}

其中代码

BLLFactory<ReimbursementDetail>.Instance.InsertUpdate(detailInfo, detailInfo.ID);

可以对新增记录保存,也可以对存在的记录进行更新。

通过上面的介绍,我们可以看到不同的主从表其实逻辑还是很通用的,我们可以把它们的逻辑抽取出来,通过代码生成工具进行快速生成即可。

    推荐阅读
  • 麻薯的做法和配方(做麻薯的流程)

    以下内容希望对你有帮助!麻薯的做法和配方糯米粉130克、玉米淀粉20克、纯牛奶200克、黄油40克、白砂糖5克。搅拌均匀后加入黄油。放入蒸锅大火蒸20分钟左右。蒸熟的糯米粉晶莹剔透,烫手时用硅胶刀将表面的黄油揉均匀。手带上手套防粘,继续揉搓。做好的麻薯微黄透亮、顺滑不油腻,可以拍打成团即可。

  • 女性割礼是什么意思(女性割礼简介)

    女性割礼是什么意思女性割礼是一种陋习,于四岁至八岁间进行,目的是割除一部分性器官,以免除其性快感,并且女性割礼确保女孩在结婚前仍是处女,即使结婚后也会对丈夫忠贞。始于古埃及法老时代,非洲仍然存在。丹溪草先生在《人类命运:变迁与规则》认为:女性割礼是人类早期,母系社会时,控制生殖资源的一种手段。现今残存于某些国家、部落的女性割礼,就是例证。早期族群头人通过割礼来控制繁衍,继而控制族群的目的。

  • 真人注射除皱案例(为什么这两年注射除皱越来越火)

    因为现在市面上涉及注射除皱的材料有很多种,不同的注射除皱材料除皱的原理是有不同的体现。注射除皱作为当代社会年轻化治疗的主流方式之一,近几年来深受广大求美者的喜爱。再一个就是采用注射方式除皱、填充的操作比较便捷,治疗过程很快,除皱的效果可立刻显现而且注射除皱的成本会比手术除皱的成本更低,性价比更高。

  • 速派陡坡起步按键(速派朗逸加油跳枪后还能再加10升)

    在2001年的《汽车燃油箱安全性能及要求试验》中规定,汽车燃油箱的额定容量应规定为不超过汽车燃油箱实际容量的95%。因为这项标准,导致许多车辆的燃油箱实际是可能装载超过标准容量的汽油的。并且汽车燃油箱的额定容量是由汽车厂家标注的,一般情况下,厂家标注容量时,会刻意缩小容量范围,所以造成了不少汽车加油时,加满的油量会超过实际油箱容量标准。

  • 微信怎么在群里发长视频 微信怎么在群里发长视频16分钟的视频

    微信在群里发长视频需要通过收藏分享来操作。其方法是:1、首先登录微信页面,在“我”的界面,点击“收藏”按加号。

  • 有创意的秀恩爱朋友圈(适合秀恩爱发的句子)

    我们一起去了解并探讨一下这个问题吧!有创意的秀恩爱朋友圈生命虽短,爱却绵长水落红莲,唯闻玉磬。电话里的沉默不是拖延,而是舍不得。拉你的左手,在雨中无尽头奔跑,最后最后,我们幸福的依偎。心如荒岛,囚我终老。无论你在哪里,我永远是那个最牵挂你的笨蛋。世界上最好闻的味道就是你身上的味道。也许放弃,才能靠近你,不再见你,你才会把我记起。桃之夭夭,灼灼其华。守一段情,念一个人。

  • 西芹炒蘑菇的做法(西芹炒蘑菇的做法介绍)

    我们一起去了解并探讨一下这个问题吧!西芹炒蘑菇的做法主料:蘑菇250g、西芹250g。辅料:食盐适量、鸡精适量、姜适量、蒜适量、红椒1个、荸荠适量。将蘑菇、马蹄切片。西芹切成段,辣椒切片。起油锅,爆香姜蒜,将蘑菇下锅煸炒。蘑菇炒软后,将其它材料下锅一起炒至断青。下盐、鸡精调味就好了。

  • 浸泡一夜米再煮粥好吗(浸泡了一夜的大米煲粥好吗)

    2、大米是不建议泡一个晚上再煮的,一方面是因为大米浸泡时间超过4小时,大米就容易出现异味、霉变等变质的情况,食用后会积累体内毒素,影响自身健康,常伴有腹痛、腹泻等不适症状,另一方面是因为大米是一种水溶性物质,泡的时间过长,营养物质流失也较多,这样的大米会失去原来的口感、色、像、味都有所下降,所以大米最好不要泡一个晚上。

  • 玉米排骨汤怎么做好吃又简单(一学就会快手菜)

    广东人最爱的煲汤By醒醒小厨房用料骨头500g玉米1根淮山1根胡萝卜1根姜片3片做法步骤1、准备骨头2、洗净冷水下锅3、水开捞出洗净4、准备一个砂锅放入洗干净的骨头,跟姜片。欢迎在下方留言分享您对这道美食的建议。

  • 面粉怎么做好吃既简单又好吃(具体有什么做法)

    面粉怎么做好吃既简单又好吃用面粉做饼,把一斤的面粉放入盆中,加入三克的酵母和五克的白糖,在面粉中加入白糖,能有效的促进酵母快速发酵,有效的缩短了时间。在面粉中再加入四个土鸡蛋,先用筷子搅散,然后再加入牛奶,牛奶要分次加入,和成软硬适中的光滑面团,盖上保鲜膜或盖子,放在温暖出发酵40分钟左右。做成花生糕,将花生用搅拌机磨成小颗粒,面粉,澄粉混合,加入花生粒和水还有糖,搅成糊状,放入锅中蒸15分钟即可。