体检套餐管理系统 -- Dictionary<K,V>双列集合

本文章为 Dictionary<K,V>双列集合开发项目,如需要List<T>单列集合开发的此项目,请到楼主博客园寻找

博客网址:http://www.cnblogs.com/lsy131479/

窗体

一.首先创建项目类

 public class HealthCheckItem
    {
        //项目描述
        private string description;
        //项目名称
        private string name;
        //项目价格
        private int price;

        //无参构造
        public HealthCheckItem()
        {
        }

        //有参构造
        public HealthCheckItem(string description, string name, int price)
        {
            this.description = description;
            this.name = name;
            this.price = price;
        }

        public string Description { get => description; set => description = value; }
        public string Name { get => name; set => name = value; }
        public int Price { get => price; set => price = value; }
    }

二.创建套餐类

/// <summary>
    /// 套餐类
    /// </summary>
   public class HealthCheckSet
    {
        //套餐名
        private string name;
        //套餐总价格
        private int price;
        //存储套餐内的项目
         private Dictionary<string, HealthCheckItem> items = new Dictionary<string, HealthCheckItem>();

        //无参构造
        public HealthCheckSet()
        {
        }
        //有参构造
        public HealthCheckSet(string name)
        {
            this.name = name;
            
        }

        

        public string Name { get => name; set => name = value; }
        public int Price { get => price; set => price = value; }
        public Dictionary<string, HealthCheckItem>{ get => items; set => items = value; }
    }

三.主窗体代码

   /// <summary>
    /// 体检套餐管理系统 -- Dictionary<K,V>双列集合
    /// </summary>
    public partial class FrmMain : Form
    {
        public FrmMain()
        {
            InitializeComponent();
        }

        private void FrmMain_Load(object sender, EventArgs e)
        {
            //删除多余列
            this.dataGridView1.AutoGenerateColumns = false;
            //清楚多余行
            this.dataGridView1.AllowUserToAddRows = false;

            /*
             * 套餐下拉框初始化
             * */
            HealthCheckSet set0 = new HealthCheckSet("请选择");
            HealthCheckSet set1 = new HealthCheckSet("入学体检");
            set.Add(set0.Name, set0);
            set.Add(set1.Name, set1);
            AddExamCbo();
        }

        //刷新项目下拉框
        public void AddExamCbo()
        {
            BindingSource source = new BindingSource();
            source.DataSource = set.Keys;
            this.cboExams.DataSource = source;
        }
        //套餐集合
        Dictionary<string, HealthCheckSet> set = new Dictionary<string, HealthCheckSet>();
        //初始化项目集合
        Dictionary<string, HealthCheckItem> allItems = new Dictionary<string, HealthCheckItem>();
        public void AddPhyCbo()
        {
            /*
             * 初始化(刷新)项目下拉框
             * */
            allItems.Clear();
            HealthCheckItem item1 = new HealthCheckItem("用于检查身高。", "身高", 5);
            HealthCheckItem item2 = new HealthCheckItem("用于检查体重。", "体重", 5);
            HealthCheckItem item3 = new HealthCheckItem("用于检查肝功能。", "肝功能", 50);
            HealthCheckItem item4 = new HealthCheckItem("用于检查视力。", "视力", 5);
            HealthCheckItem item5 = new HealthCheckItem("用于检查听力。", "听力", 5);
            HealthCheckItem item6 = new HealthCheckItem("用于检查B超。", "B超", 80);
            HealthCheckItem item7 = new HealthCheckItem("用于检查心电图。", "心电图", 100);
            allItems.Add(item1.Name, item1);
            allItems.Add(item2.Name, item2);
            allItems.Add(item3.Name, item3);
            allItems.Add(item4.Name, item4);
            allItems.Add(item5.Name, item5);
            allItems.Add(item6.Name, item6);
            allItems.Add(item7.Name, item7);
            this.cboPhy.DisplayMember = "name";
            BindingSource source = new BindingSource();
            source.DataSource = allItems.Keys;
            this.cboPhy.DataSource = source;
        }

        private void cboExams_SelectedIndexChanged(object sender, EventArgs e)
        {
            /*
             * 改变下拉框下标,判断下标。改变状态
             * */
            this.lblNames.Text = this.cboExams.Text;
            RenovateDgv();
            Btn();
            if (this.cboExams.SelectedIndex > 0)
            {
                this.btnAdd.Enabled = true;
                AddPhyCbo();
            }
            else
            {
                this.btnAdd.Enabled = false;
                this.cboPhy.DataSource = null;
            }
        }

        private void btnNew_Click(object sender, EventArgs e)
        {
            //非空验证
            if (txtNewName.Text == "" || txtNewName.Text == null)
            {
                MessageBox.Show("请输入套餐名称!");
                return;
            }
            /*
             * 集合添加套餐名
             * 并刷新下拉框
             * */
            HealthCheckSet set3 = new HealthCheckSet(this.txtNewName.Text);
            set.Add(set3.Name, set3);
            AddExamCbo();
            this.cboExams.Text = set3.Name;
            MessageBox.Show("添加成功!");
        }

        public void AddDgv()
        {
            //ToList()将双列集合转为单列集合
            //Contains()在单列集合中寻找是否已存在该项
            if (set[cboExams.Text].Items.Keys.ToList().Contains(this.cboPhy.Text))
            {
                MessageBox.Show("您已添加过此项!");
                return;
            }
            /*
             * 向套餐内添加项目
             * */
            set[cboExams.Text].Items.Add(cboPhy.Text, allItems[cboPhy.Text]);
            Btn();
            MessageBox.Show("添加成功!");

        }
        public void RenovateDgv()
        {
            /*
             * 刷新datagridview
             * */
            BindingSource source = new BindingSource();
            source.DataSource = set[cboExams.Text].Items.Values;
            dataGridView1.DataSource = source;
        }
        private void btnAdd_Click(object sender, EventArgs e)
        {
            /*
             * 添加套餐项目
             * */
            AddDgv();
            RenovateDgv();
        }

        public void Btn()
        {
            /*
             * 由集合内是否有元素,来改变删除按钮的状态
             * */
            if (set[cboExams.Text].Items.Count > 0)
            {
                this.btnDel.Enabled = true;
            }
            else
            {
                this.btnDel.Enabled = false;
            }

            /*
             * 计算套餐总金额
             * 并刷新控件
             * */
            set[cboExams.Text].Price = 0;
            foreach (KeyValuePair<string, HealthCheckItem> it in set[cboExams.Text].Items)
            {
                set[cboExams.Text].Price += it.Value.Price;
            }
            this.lblPrices.Text = set[cboExams.Text].Price.ToString();
        }

        private void btnDel_Click(object sender, EventArgs e)
        {
            /*
             * 由键来移除指定的集合元素
             * 并刷新控件显示的值与状态
             * */
            set[cboExams.Text].Items.Remove(this.dataGridView1.SelectedRows[0].Cells[0].Value.ToString().Trim());
            RenovateDgv();
            Btn();
            MessageBox.Show("删除成功!");
        }
    }

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏菩提树下的杨过

利用fluorineFx将DataTable从.Net传递到Flash

FluorineFx自带的示例都不错,就是有点不简洁,下面的代码基本上已经最简版了(环境vs2010) 1、先创建一个Web Application,然后添加F...

2315
来自专栏ASP.NET MVC5 后台权限管理系统

构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(13)-系统日志和异常的处理③

上一节我们讲了如何捕获异常和记录日志,这一节我们讲,没有捕获的或者忘记捕获的异常包括404错误等,我们统一处理这个异常。 这一讲是利用 Application_...

2868
来自专栏偏前端工程师的驿站

GridView实战一:自定义分页、排序、修改、插入、删除

前言:   在某次公司面试时被问到对GridView操作的熟悉程度,在那之前一直用Repeater内嵌table标签对GridView操作确实很少,于是最近在项...

33610
来自专栏逸鹏说道

Dapper逆天入门~强类型,动态类型,多映射,多返回值,增删改查+存储过程案例演示

Dapper的牛逼就不扯蛋了,答应群友做个入门Demo的,现有园友需要,那么公开分享一下: 完整Demo:http://pan.baidu.com/s/1i3T...

3387
来自专栏Porschev[钟慰]的专栏

前台JS(Jquery)调用后台方法 无刷新级联菜单示例

前台用AJAX直接调用后台方法,老有人发帖提问,没事做个示例 CasMenu.aspx页面: <%@ Page Language="C#" AutoEventW...

2755
来自专栏岑玉海

RavenDb学习(四)处理文档相关性

RavenDb是文档型数据库,但是我们常常也需要定义对象之间的关系,那RavenDb当中是如何处理的呢? RavenDb提供了优雅的解决方式,使用正确的话,可以...

2815
来自专栏木宛城主

SharePoint 2013 How to Backup Site Collection Automatically With a PowerShell Script

In this post I will introduce a way how to run a script for backing up SharePoin...

2337
来自专栏飞扬的花生

C#实现Excel模板导出和从Excel导入数据

      午休时间写了一个Demo关于Excel导入导出的简单练习 1.窗体 ? 2.引用office命名空间 添加引用-程序集-扩展-Microsoft.O...

4897
来自专栏跟着阿笨一起玩NET

关于asp.net与winform导出excel的代码

一、asp.net中导出Execl的方法: 在asp.net中导出Execl有两种方法,一种是将导出的文件存放在服务器某个文件夹下面,然后将文件地址输出在...

751
来自专栏跟着阿笨一起玩NET

ASP.NET多线程下使用HttpContext.Current为null解决方案

前面我还提到在APM模式下的异步完成回调时,访问HttpContext.Current也会返回null,那么此时该怎么办呢?

1392

扫码关注云+社区