C#动态添加DataGridView列和行

在WinForm的C#应用中,DataGridView作为重要的数据组织和显示控件,作用极大。在DataGridView的数据组织时,一般都采用数据源绑定的方式(DataSource)与DataSet、Datatable或List来组织,很少出现不使用DataSource而动态添加的方式。所以网上有关这方面的介绍比较少或太简单,并且实用的例子很少。这次有同学有个需求问我要一个处理这种动态添加列和添加列的方法。下面就选取涉及动态组织DataGridView实例部分列示如下,供参考:

        private void GetDGVData()
        {
            dataGridView1 = DynamicCreationDGV(dataGridView1);
        }

        private DataGridView DynamicCreationDGV(DataGridView dgv)
        {
            if (dgv == null)
                return null;
            if (dgv.ColumnCount != 0)
                dgv.Columns.Clear();    //清除现有列

            #region 组织 DataGridViewColumn
            for (int i = 0; i < 6; i++) //指定总列数
            {
                //列名和列头名
                string dgvColName = "Col"+i;
                string dgvColHeaderText = string.Empty;

                if (i<=4)   //设置部分列头名
                    dgvColHeaderText = "Header_"+i;

                DataGridViewColumn dgvc
### 动态添加C# WinForms DataGridView 控件 在 C# WinForms 中,可以通过编程方式向 `DataGridView` 添加。以下是实现此功能的一个完整示例: #### 创建并添加 通过创建一个新的 `DataGridViewTextBoxColumn` 或其他类型的(如 `DataGridViewCheckBoxColumn`),可以将其添加到 `DataGridView.Columns` 集合中。 ```csharp // 创建一个新的文本 DataGridViewTextBoxColumn column = new DataGridViewTextBoxColumn(); column.Name = "NewColumnName"; // 设置名 column.HeaderText = "Header Text"; // 设置显示的表头文字 column.DataPropertyName = "PropertyBinding"; // 如果绑定数据源,则设置属性名称 dataGridView1.Columns.Add(column); // 将新添加DataGridView ``` 如果需要动态调整样式或其他特性,可以根据引用中的描述进操作[^3]。例如,定义统一的单元格样式以提高效率。 #### 定义单元格样式 为了优化性能,建议共享同一个 `DataGridViewCellStyle` 对象而不是为每个单元格单独创建样式对象。 ```csharp // 创建一个通用的单元格样式 DataGridViewCellStyle style = new DataGridViewCellStyle(); style.BackColor = Color.LightGray; // 背景色 style.ForeColor = Color.DarkBlue; // 前景色 style.Font = new Font("Arial", 10, FontStyle.Bold); // 字体 // 应用样式到特定 dataGridView1.Columns["NewColumnName"].DefaultCellStyle = style; ``` 以上方法能够有效减少内存消耗提升渲染速度。 #### 处理事件 当需要处理某些交互为时,比如检测错误输入或响应用户动作,可利用事件机制完成逻辑控制。例如,在单元格验证失败时记录位置信息。 ```csharp private void dataGridView1_CellValidating(object sender, DataGridViewCellValidatingEventArgs e) { if (string.IsNullOrEmpty(e.FormattedValue.ToString())) { dataGridView1.Rows[e.RowIndex].ErrorText = "This field cannot be empty."; // 记录发生错误的位置 Point cellInError = new Point(e.ColumnIndex, e.RowIndex); } } ``` 上述代码片段展示了如何捕获无效输入的情况,并标记相应的作为错误状态[^2]。 --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值