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

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

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

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

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

「应用界面优化」Winform开发主从表编辑界面的快速处理

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

「应用界面优化」Winform开发主从表编辑界面的快速处理

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

「应用界面优化」Winform开发主从表编辑界面的快速处理

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

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

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

「应用界面优化」Winform开发主从表编辑界面的快速处理

其中初始化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);

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

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

版权声明:本文图片和内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送联系客服 举报,一经查实,本站将立刻删除,请注明出处:https://www.4kpp.com/7347.html

(0)
漫空客漫空客
上一篇 2023年4月23日
下一篇 2023年4月23日

相关推荐

  • 淘i宝(淘i宝网)

    “快递盲盒最吸引我的地方,就是总觉得自己能捡到‘漏’,感觉很刺激,但是拍了几次,什么‘漏’也没捡到……‘618’过后,家里堆了一堆‘鸡肋’。”日前,在经历了“快递盲盒”“刺激”之后…

    投稿 2023年4月23日
    2960
  • 增值税免税政策有哪些(增值税纳税优惠政策)

    今年以来,国家出台了一系列减税降费的政策措施,减轻了企业负担,增强了市场主体活力。国家税务总局最新数据显示,今年前三季度,全国新增减税降费9101亿元,其中新增减税7889亿元。各…

    投稿 2023年4月23日
    4560
  • 京东运费怎么算(京东两个账号怎么合并成一个)

    一切都与快递有关。就在京东高调宣布其获得25亿美元京东物流融资的同时,京东商城低调的进行了快递费用涨价,这一切都发生在春节前人们忙于过年疏于购物的最佳时刻。 据最新的快递费用价目表…

    投稿 2023年4月23日
    1470
  • 恢复u盘删除的文件(怎么恢复u盘里面删除的文件)

    今天小编给各位分享恢复u盘删除的文件(怎么恢复u盘里面删除的文件),如果能碰巧解决你现在面临的问题,别忘了关注小站,我们一起开始吧! 如何用u盘恢复当天删除的文件? u盘上误删的文…

    投稿 2023年4月23日
    2170
  • 石灰吟的诗意(石灰吟的诗意简短20字)

    今天给大家介绍一下石灰吟的诗词,以及石灰吟短诗20个字对应的知识点。希望对你有帮助,也别忘了收藏这个站点。 石灰窑的意义与诗意 诗:是从深山里经过漫长的奋斗开采出来的,火的燃烧是常…

    投稿 2023年4月23日
    1280
  • 林彪死后周恩来为何嚎啕大哭?

      1971年,注定是多事之秋。这一年的9月13日,中共中央唯一的副主席、毛泽东的法定接班人林彪,乘坐一架中国民航256号三叉戟,在出逃苏联途中因飞机出事,坠毁于蒙古温都尔汗附近肯…

    投稿 2023年4月22日
    1490
  • 抖音三角形旁边的数字是什么意思

    抖音977是啥,这个最近在抖音上面火了,大家不清楚其中的含义和出处,经常会在一些地方出现的,到底指代什么,下面就来介绍下抖音977什么意思。 抖音977含义一览 一、意思 这个主要…

    2023年4月22日
    1070
  • 怎么刷钻教程(如何刷钻)

    视频: 4月29日最新天天酷跑刷分 刷钻石 刷积分 刷金币教学 100%不封号, 天天酷跑刷分刷钻石视频终于出来了,小伙伴们再也不用担心自己的分数太低而难堪,这部视频堪称天天酷跑刷…

    投稿 2023年4月23日
    2660
  • 拉萨特产有哪些(拉萨特产有哪些值得带)

    今天小编给各位分享 *** 特产有哪些( *** 特产有哪些值得带),如果能碰巧解决你现在面临的问题,别忘了关注小站,我们一起开始吧! *** 有哪些值得一去的特产? 主要特产之一…

    投稿 2023年4月23日
    1420
  • 淘宝客推广怎么操作

    淘宝正在帮助淘宝卖家推广货物,并根据交易效应(可以成为个人或网站),从2009年1月12日开始,正式更名为淘宝。 “淘宝”是指淘宝卖家的帮助……淘宝是一个帮…

    投稿 2023年4月23日
    1120

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注