datagridviewcomboboxcell值无效的解决办法

本文介绍了一种在Visual Studio 2005 WinForms应用程序中解决DataGridView出现错误的方法。当更改数据源后,如果遇到类型不匹配的错误,可以检查字典表的标识字段类型是否与信息表的对应字段类型一致。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本说明是针对vs2005winform程序,在为datagridview设置datagridviewcomboboxcell列时,系统显示如题错误的解决方法。

在改一同事的功能模块时,由于数据源不符,改变数据源后,系统即提示如题报错,先行网上查找问题未果。

在浪费了本人很多时间的情况下,才找出错误源,问题出在字典表的标识字段类型与信息表对应的字段类型不以至,最根源的问题还是分工不合理所至,郁闷。。。。。

也给找不出原因的P们提个醒

转载于:https://www.cnblogs.com/flowstarxx/archive/2007/12/12/991778.html

``` public partial class FrmTLConfig : Form { public FrmTLConfig() { InitializeComponent(); dgv_TowerLight.AllowUserToAddRows = false; // 禁止添加新行 dgv_TowerLight.AllowUserToDeleteRows = false;// 禁止删除已有行 UpdateTLConfigUi(); } private void UpdateTLConfigUi() { var dataSource = ParamManager.Instance.LocalParam.TowerLightConfigurationParam.ConfigurationModels; if (dataSource != null) { dgv_TowerLight.DataSource = new BindingList<TowerLightConfigurationModel>(dataSource); } //dgv_TowerLight.AutoGenerateColumns = false; // 禁用自动生成列 // 记录需要替换的列名 List<string> columnsToReplace = new List<string>(); // 获取列名 foreach (DataGridViewColumn column in dgv_TowerLight.Columns) { if (column.Name == "MachineStatus") { continue; } columnsToReplace.Add(column.Name); } //替换列 foreach (string columnName in columnsToReplace) { ReplaceColumn(columnName); } // 同步下拉框的选中 //SyncComboBoxValues(); } private void ReplaceColumn(string columnName) { // 创建一个 DataGridViewComboBoxColumn DataGridViewComboBoxColumn comboCol = new DataGridViewComboBoxColumn { Name = columnName, HeaderText = columnName, DataPropertyName = columnName, DataSource = Enum.GetValues(typeof(TLState)), // 绑定枚举数据源 ValueType = typeof(TLState) }; // 替换原有列(或添加新列) int index = dgv_TowerLight.Columns.Contains(columnName) ? dgv_TowerLight.Columns[columnName].Index : dgv_TowerLight.Columns.Count; if (dgv_TowerLight.Columns.Contains(columnName)) { dgv_TowerLight.Columns.RemoveAt(index); } dgv_TowerLight.Columns.Insert(index, comboCol); } private void btn_Save_Click(object sender, EventArgs e) { // 保存逻辑 for (int rowIndex = 0; rowIndex < dgv_TowerLight.Rows.Count; rowIndex++) { DataGridViewRow row = dgv_TowerLight.Rows[rowIndex]; TowerLightConfigurationModel model = (TowerLightConfigurationModel)dgv_TowerLight.Rows[rowIndex].DataBoundItem; foreach (DataGridViewColumn column in dgv_TowerLight.Columns) { if (column.Name == "MachineStatus") { continue; } DataGridViewComboBoxCell comboBoxCell = (DataGridViewComboBoxCell)row.Cells[column.Name]; typeof(TowerLightConfigurationModel).GetProperty(column.Name).SetValue(model, comboBoxCell.Value); } } } } dgv_TowerLight绑定的是数据库的数据,界面加载时会出现DataGridViewComboBoxCell无效```dgv_TowerLight绑定的是数据库的数据,界面加载时会出现DataGridViewComboBoxCell无效
03-29
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值