• 设置DataGridViewComboBoxColumn列的默认值


      因为工作需要,最近用到了DataGridViewComboBoxColumn,需要让它在DataGridView中显示时包含默认值。在网上查找过相关资料,对于我这种新手来说理解起来仍是困难,索性自己动手写了一个测试程序,若有说的不对的地方欢迎拍砖:-)。

      DataGridViewComboBoxColumn列用于在DataGridView单元格中实现具有类似ComboBox的功能,就是可以从下拉框中选择需要显示在单元格中的内容。在设置默认值的时候,有两种情况:一是DataGridView显示时已绑定了数据源;二是DataGridView显示时未绑定数据源,只是在新增行时需要显示默认值。

      第一种情况,假设DataGridView显示到界面时已绑定了数据源,我们需要设置DataGridViewComboBoxColumn列的DataPropertyName列为DataGridView绑定的数据源列的名称,部分代码如下:

    DataTable dept = new DataTable();
    DataColumn col = new DataColumn("dept_id", Type.GetType("System.String")) { Unique = true };//学院代码
    dept.Columns.Add(col);
    col = new DataColumn("dept_name", Type.GetType("System.String"));//学院名称
    dept.Columns.Add(col);
    dept.Rows.Add("001", "计算机学院");
    dept.Rows.Add("002", "电气学院");
    dept.Rows.Add("003", "机械学院");
     
    DataGridViewComboBoxColumn cbxCol = new DataGridViewComboBoxColumn
    {
    Name = "Udept",
    DataSource = dept,
    DisplayMember = "dept_name",//DataGridViewComboBoxColumn数据源中的列
    ValueMember = "dept_id",
    DataPropertyName = "Udept",//注意,DataGridView数据源中的列
    HeaderText = "学院",
    DisplayStyle = DataGridViewComboBoxDisplayStyle.DropDownButton//这里设置为DropDownButton是为了看起来更像ComboBox
    };
    dgv.Columns.Add(cbxCol);

    可以看到DisplayMember和ValueMember属性与ComboBox中的使用是一样的,并且ValueMember与DataPropertyName值也不同(这样看起来数据源比较有层次,也可以设置为相同,不过理解起来不是特别直观),DataGridView绑定的数据源为stu,其声明如下,

    DataTable stu = new DataTable();
    DataColumn col = new DataColumn("Uno", Type.GetType("System.String"));//学号
    stu.Columns.Add(col);
    col = new DataColumn("Uname", Type.GetType("System.String"));//姓名
    stu.Columns.Add(col);
    col = new DataColumn("Udept", Type.GetType("System.String"));//院系
    stu.Columns.Add(col);
    stu.Rows.Add("2013001", "Jerry", "001");
    stu.Rows.Add("2013002", "Tom", "002");
    stu.Rows.Add("2013003", "Mike", "003");

    可以看到stu表中Udept列的数据全部来源于dept表中的dept_id列。

    当在Form_Load()中绑定DataGridView数据源时效果如下:

      第二种情况,DataGridView显示时未绑定数据源,只是在新增行时需要显示默认值,部分代码如下:

    需要将DataGridView的AllowUserToAddRows属性设为false,为true时新增的行不能设置默认值(能力有限,还没找到办法,希望大家不吝赐教~);新建AddNewRow()方法如下,

    private void AddNewRow()
    {
    DataRowView dr = ((DataTable)dgv.DataSource).DefaultView.AddNew();
    dr["Udept"] = "001";//这里注意,DataGridView的数据源中"学院"一列对应的是Udept,千万别写成dept_id了
    dr.EndEdit();
    }

    新增行时指定了Udept列的值为"001",那么每次点击添加新行时,"学院"一栏都是"计算机学院"了,效果如下:

    需要完整源码的请留言,大家共同进步吧;-)

  • 相关阅读:
    DB9 ------ 接口定义
    以太网 ------ Auto-Negotiation(自动协商)
    Qt ------ 添加某个功能,比如(QSerialPort)注意事项
    Modbus
    Centos7.5 安装JDK1.8 步骤
    Kafka 消息中间件
    使用RabbitMQ实现分布式事务
    RabbitMq的环境安装
    RabbitMQ消息中间件的用法
    基于Docker+Jenkins实现自动化部署
  • 原文地址:https://www.cnblogs.com/LuoFB/p/4139545.html
Copyright © 2020-2023  润新知