Winform界面基于多页面数据的处理实现

我们在做Winform项目开发的时候,经常会发现有一些数据很多,需要通过不同的Tab页面分类来实现数据的录入和现实,例如体检数据,可能包含外科、内科、眼科、耳鼻喉科、口腔科、以及其他的检查等等内容,如果一次性放在一个窗口中现实,不太合理也不好看,如果通过多个Tab分类进行管理,则用户体验好很多。

如果分为多个Tab页面进行数据管理,最好的方法是,每个页面负责自己的数据存储及显示,由于数据可能是关联的,存储需要使用事务。保存的时候,可能每项都会有检查数据是否完备及有效性。那么我们应该实现类似这样的界面操作呢。

如上分析,我们把每个模块独立出来做一个控件,如眼科的作为一个独立的用户控件进行展现,如下所示。

其他模块也一样处理,独立作为一个用户控件,然后再在一个主窗体界面中进行整合即可。

为了对窗体能够实现批量处理,我们需要为每个用户控件定义一个接口,他们之间都需要实现这些约定的接口,接口如下所示。

    interface IDataApply
    {
        /// <summary>
        /// 设置控件的重要属性
        /// </summary>
        /// <param name="id">记录ID</param>
        /// <param name="pilotId">飞行人员ID</param>
        /// <param name="isNewData">是否为新建记录</param>
        void SetData(string id, string pilotId, bool isNewData);

        /// <summary>
        /// 数据显示的函数
        /// </summary>
        void DisplayData();

        /// <summary>
        /// 用于模块事务性提交数据
        /// </summary>
        /// <param name="trans">事务对象</param>
        /// <returns></returns>
        bool Apply(DbTransaction trans);

        /// <summary>
        /// 检查输入的有效性
        /// </summary>
        /// <returns>有效</returns>
        bool CheckInput();
    }

这样,独立的用户控件需要继承接口,实现接口约定的内容。

public partial class EyeControl : DevExpress.XtraEditors.XtraUserControl, IDataApply

我们来看其中一个TabPage的模块接口实现代码如下所示。

        #region IDataApply 成员

        /// <summary>
        /// 检查输入的有效性
        /// </summary>
        /// <returns>有效</returns>
        public bool CheckInput()
        {
            bool result = true;//默认是可以通过
            if (this.txtCheckDate.Text.Length == 0)
            {
                MessageDxUtil.ShowTips("请输入体检结论日期");
                this.txtCheckDate.Focus();
                return false;
            }

            return result;
        }

        /// <summary>
        /// 设置控件的重要属性
        /// </summary>
        /// <param name="id">记录ID</param>
        /// <param name="pilotId">飞行人员ID</param>
        /// <param name="isNewData">是否为新建记录</param>
        public void SetData(string id, string pilotId, bool isNewData)
        {
            this.ID = id;
            this.Pilot_ID = pilotId;
            this.IsNewData = isNewData;
        }

        /// <summary>
        /// 数据显示的函数
        /// </summary>
        public void DisplayData()
        {
            InitDictItem();//数据字典加载(公用)

            if (!this.IsNewData)
            {
                #region 显示客户信息
                LargeCheckConclusionInfo info = BLLFactory<LargeCheckConclusion>.Instance.FindByID(ID);
                if (info != null)
                {
                    txtCheckDate.DateTime = info.CheckDate;
                    txtDiagnosis.Text = info.Diagnosis;
                    txtResult.Text = info.Result;
                    txtSuggestion.Text = info.Suggestion;
                    txtHealthLevel.Text = info.HealthLevel;
                    txtHospital.Text = info.Hospital;
                }
                #endregion
            }
            else
            {
            }
        }

        /// <summary>
        /// 用于模块事务性提交数据
        /// </summary>
        /// <param name="trans">事务对象</param>
        /// <returns></returns>
        public bool Apply(DbTransaction trans)
        {
            this.trans = trans;

            bool result = false;
            if (!this.IsNewData)
            {
                //编辑的保存
                result = SaveUpdated();
            }
            else
            {
                //新增的保存
                result = SaveAddNew();
            }

            return result;
        }

        #endregion

其中我们注意到,各模块的数据显示及保存,都是自治的,这样除了较好管理数据显示及保存外,也使得主界面整合更加简洁方便。

在主编辑界面中,我们需要逐一对各个控件的检查,以及数据保存及显示等操作进行处理,具体我们可以通过遍历进行处理。

1)检查控件输入的部分如下代码所示。

        /// <summary>
        /// 检查输入的有效性
        /// </summary>
        /// <returns>有效</returns>
        public virtual bool CheckInput()
        {
            bool result = true;//默认是可以通过
            if (this.txtPilot.PilotID.Trim().Length == 0)
            {
                MessageDxUtil.ShowTips("请选择飞行人员");
                this.txtPilot.Focus();
                result = false;
            }

            //检查输入是否正确
            foreach (XtraTabPage page in this.xtraTabControl1.TabPages)
            {
                foreach (Control control in page.Controls)
                {
                    IDataApply apply = control as IDataApply;
                    if (apply != null)
                    {
                        apply.SetData(ID, this.txtPilot.PilotID, IsNewData);
                        result = apply.CheckInput();
                        if (!result)
                        {
                            this.xtraTabControl1.SelectedTabPage = page;
                            control.Focus();
                        }
                    }
                }
            }

            return result;
        }

2)显示每个控件负责的数据,操作代码如下所示。

         /// <summary>
        /// 显示数据到控件上
        /// </summary>
        public virtual void DisplayData()
        {
            InitDictItem();//数据字典加载(公用)

            foreach (XtraTabPage page in this.xtraTabControl1.TabPages)
            {
                foreach (Control control in page.Controls)
                {
                    IDataApply apply = control as IDataApply;
                    if (apply != null)
                    {
                        apply.SetData(ID, Pilot_ID, IsNewData);
                        apply.DisplayData();
                    }
                }
            }
        } 

3)采用事务性保存数据的实现代码如下所示

        /// <summary>
        /// 保存数据(新增和编辑的保存)
        /// </summary>
        public virtual bool SaveEntity()
        {
            bool result = false;

            DbTransaction trans = BLLFactory<LargeCheckConclusion>.Instance.CreateTransaction();
            if (trans != null)
            {
                try
                {
                    foreach (XtraTabPage page in this.xtraTabControl1.TabPages)
                    {
                        foreach (Control control in page.Controls)
                        {
                            IDataApply apply = control as IDataApply;
                            if (apply != null)
                            {
                                apply.SetData(ID, this.txtPilot.PilotID, IsNewData);
                                apply.Apply(trans);
                            }
                        }
                    }

                    if (trans != null)
                    {
                        trans.Commit();
                        result = true;
                    }
                }
                catch (Exception ex)
                {
                    if (trans != null)
                    {
                        trans.Rollback();
                    }

                    LogHelper.Error(ex);
                    MessageDxUtil.ShowError(ex.Message);
                    return false;
                }
            }

            return result;
        }

实现以上的操作,基本上对控件的数据管理就差不多了,这样比我们把全部鸡蛋放到一个篮子里面处理,会显得更加清晰,更加高效,重要的是减少出错的机会,否则想想看,如果操作的数据字段内容上百个,保存,显示,检查这些操作,是不是很容易漏掉,或者出现错误呢。况且把每部分鸡蛋放到一个小篮子里面,我们管理就是小篮子,这样管理的对象减少了,效率也就提高了。

以上就是对于多个Tab页面的数据处理解决方案,应该对大家有一定的启发意义。

本文转自博客园伍华聪的博客,原文链接:Winform界面基于多页面数据的处理实现,如需转载请自行联系原博主。

时间: 2024-10-29 00:24:45

Winform界面基于多页面数据的处理实现的相关文章

求C#在winform界面下读写EXCEL数据以及读写文本文件的源码和示例

问题描述 求C#在winform界面下读写EXCEL数据以及读写文本文件的源码和示例 解决方案 解决方案二:你先看看这个http://blog.csdn.net/duanzi_peng/article/details/17414629解决方案三:百度上就能搜到解决方案四:1:http://blog.csdn.net/pan_junbiao/article/details/397174432:File.ReadAllLines或者使用StreamReader这种例子网上一搜一吨多.解决方案五:读写

Winform界面中实现菜单列表的动态个性化配置管理

在我们一般的应用系统里面,由于系统是面向不同类型的用户,我们所看到的菜单会越来越多,多一点的甚至上百个,但是我们实际工作接触的菜单可能就是那么几个,那么对于这种庞大的菜单体系,寻找起来非常不便.因此对菜单的个性化配置就显得尤为重要,本篇随笔就是基于这样的理念,提供用户对可见菜单进行一个动态配置,只选自己喜欢.常用的菜单显示出来即可,菜单的配置存储在数据库里面,在不同的客户端体验都是一样.本篇随笔主要介绍实现这样的功能的一个完整思路,部分代码逻辑可供参考. 1. 菜单列表的动态个性化配置的过程 在

循序渐进开发WinForm项目(5)--Excel数据的导入导出操作

随笔背景:在很多时候,很多入门不久的朋友都会问我:我是从其他语言转到C#开发的,有没有一些基础性的资料给我们学习学习呢,你的框架感觉一下太大了,希望有个循序渐进的教程或者视频来学习就好了. 其实也许我们每天面对的太多东西了,觉得很多都稀松平常了,即使很细微的地方,可能我们都已经形成习惯了.反过来,如果我们切换到其他领域,如IOS.android,那么开始我们可能对里面很多设计的规则不甚了解,开始可能也是一头雾水. 本篇继续上一篇<循序渐进开发WinForm项目(4)--Winform界面模块的集

WinForm界面开发之“分页控件”

在程序中,分页总是永远的话题,因为数据总是很多很多,分页展示在程序性能和数据查看感官方面得到很好的平衡,是一种良好的编程习惯和UI设计. Winform中的分页控件可能没有Asp.net世界中的分页控件那么丰富多彩,不过也有不少的分页控件可以采用,各个人的可能都有一些不同的东西,一些好的东西.就我而言,我希望控件能够尽可能的多一些功能,耦合性低一些,例如我不想是基于存储过程的,因为我很多程序需要使用Access作为数据库,一般来说,我还希望有导出Excel数据的功能,还有打印预览功能,由于我的数

利用JQuery方便实现基于Ajax的数据查询、排序和分页功能

ajax|分页|排序|数据        之前很少会用javascript去实现页功能主要怕麻烦,但了解JQuery后这种想法发生了变化:有了这样的脚本组件就可以在编写脚本时方便和HTML隔离出来,这样编写高重用性的脚本就更方便.下面就是介绍在学习JQuery过程中编写的基于Ajax的数据查询.排序和分页功能的复用脚本,只要遵循脚本的某些规则描述HTML把脚本文件引入就可以方便实现以上描述的功能.        先看下实现功能的脚代码: /**应用脚本规则:           引用脚本: JQ

WinForm界面开发之模块化分合

大千世界,合久必分,分久必合,分合之道,利之所趋. 开发过程,积少成多,聚沙成塔,模块之理,必经之路. 本文继续WInform界面开发系列的介绍,主要针对性介绍Winform开发过程中,经常用到的模块:数据字典模块.参数配置模块.权限管理模块的模块化应用,以及各模块的分合之道. 1.数据字典模块 我们知道,一般程序基本上都涉及到了一个是数据参考用途的数据字典模块,不管是Web还是Winform的,这个模块基本上是必不可少的,Winform的界面效果大致如下所示: 本模块的数据字典支持无限级树形分

基于云计算的数据正在优化现代初创企业

初创企业已经为市场竞争做好了准备.并想出了一个改善根深蒂固行业的惊人方法.现在是把新概念推向公众的时候了. 如果企业在这个阶段没有被问题淹没,那么可能想找到另一种谋生的方式.这将有很多方式伴产品推向市场,从雇佣销售团队到部署在线广告活动和开展展会. 基于云计算的数据平台终于为这些问题提供了明确的答案,这种形式甚至可以用于初创公司.以前需要大量人力投入的工作,现在可以通过点击鼠标来实现. 基于云计算的数据在规模上可以负担 基于云意味着信息是从各地收集和访问的.例如,人们在Facebook上所做的一

表单数据-使用springmvc中controller怎么实现JSP页面数据提交到oracle数据库,求代码。

问题描述 使用springmvc中controller怎么实现JSP页面数据提交到oracle数据库,求代码. 如何使用controller进行JSP页面输入数据的存储,如图,怎么写这个功能的代码,将咨询内容提交到后台数据库中,然后在后台管理的页面进行对该问题的回复.求大神给写个代码.谢谢. 解决方案 你要把数据传递到后台,然后在保存到数据库里面,建议使用Ajax操作,先把数据传递到后台,通过业务逻辑保存好了之后,再把你的回复通过Ajax的回调函数返回到界面 解决方案二: 怎么写的,求给个代码.

HttpRequest 抓某宝搜索页面数据 出现验证码

问题描述 求大神解救,已经2个多月了,程序通过抓某宝搜索页面数据,通过winform程序,HttpRequest方式抓,时不时会返回验证码,但是ie浏览器打开又没有弹,程序返回里又有,请问我是哪里做错了!或则说如何能避免验证码请大神解救!以下是我的HttpRequest请求数据的代码HttpWebRequestrequest=(HttpWebRequest)WebRequest.Create(url);//声明一个HttpWebRequest请求request.Timeout=30000;req