关于DataGridViewComboBoxCell修改后提交数据源
最近在项目遇到一个功能实现。是在DataGridView中DataGridViewComboboxColumn列绑定数据源,
DisplayMember为数据表的Name列,ValueMember是数据表的ID列。
需求是希望对DataGridView的ComboBoxCell进行编辑,添加新的选项并更新数据源及数据绑定。
1.使DataGridViewComboBoxCell进入编辑状态,这个很简单。做法如下:
注册DataGridView的EditingControlShowing事件,代码如下:
private void dgv_EditingControlShowing(object sender, DataGridViewEditingControlShowingEventArgs e)
{
DataGridView dgv = sender as DataGridView;
bool isRight =
dgv.CurrentCellAddress.X == ColJCFF.DisplayIndex;
if (isRight)
{
ComboBox cb = e.Control as ComboBox;
if (cb != null)
{
cb.DropDownStyle = ComboBoxStyle.DropDown;
}
}
}
2.获取输入数据,检查并实现更新数据源
注册DataGridView的CellValidating事件,判断输入的数据是否在数据源中,
如果不在那么提交更改,重新绑定DataGridViewComboboxColumn数据。代码如下:
private void dgvMode_CellValidating(object sender, DataGridViewCellValidatingEventArgs e)
{
DataGridView dgv = sender as DataGridView;
bool isempty = string.IsNullOrEmpty(e.FormattedValue.ToString());
DataGridViewComboBoxColumn cmbCol = dgv.Columns[e.ColumnIndex] as DataGridViewComboBoxColumn;
if (cmbCol == null)
return;
if (!isempty)
{
bool isCol = dgv.Columns[e.ColumnIndex].Name == cmbCol.Name;
if (isCol)
{
//现有选项中不包含输入数据
if (!cmbCol.Items.Contains(e.FormattedValue))
{
//获取数据源
DataTable dt = cmbCol.DataSource as DataTable;
if (dt == null)
return;
string valueStr = "";//新添加的ID
//判读数据源中是否包含输入数据
DataRow[] rows = dt.Select(cmbCol.DisplayMember + " = '" + e.FormattedValue + "'");
if (rows.Length == 0)//没有包含
{
string guid = GetNewID();//获取新的ID
dt.Rows.Add();
dt.Rows[dt.Rows.Count - 1][1] = e.FormattedValue.ToString();
dt.Rows[dt.Rows.Count - 1][0] = guid;
valueStr = guid;
UpDataMethod(dt);//更新数据
//重新绑定列数据源
BindColumn();
}
else//如果集合内包含此数据
valueStr = rows[0][0].ToString();
//更新DataGridView数据
ComboBox cmb = dgv.EditingControl as ComboBox;
if (cmb != null)
cmb.SelectedValue = valueStr;
}
}
}
}
要注意如下代码:
ComboBox cmb = dgv.EditingControl as ComboBox;
if (cmb != null)
cmb.SelectedValue = valueStr;
此时更新DataGridView数据是指对DataGridView的EditControl(Combobox)的数据更新,
如果你直接更新DataGridView的数据,例如:
dgv.Rows[e.RowIndex].Cells[e.ColumnIndex].Value = valueStr;
当前Cell的数据会发生改变,但是当EditControl(Combobox)随后提交数据时,
因为EditControl(Combobox)的数据没有改变,那么当前Cell的数据还会改为
EditControl(Combobox)的数据,也即当前Cell的原始数据没有改变。
这样就会使你更新DataGridViewComboBoxColumn数据源后,DataGridView当前Cell的值不是你预期的填写的数据项。
而我们直接更改EditControl(Combobox)的数据后,EditControl(Combobox)提交更改为你预期的填写的数据。
所以我们要更改EditControl(Combobox)的数据而不是当前Cell的Value。
关于DataGridViewComboBoxCell修改后提交数据源的更多相关文章
- git 学习笔记 —— 获取远端分支并修改后提交至远端仓库
笔者最近进行开发过程中,所有参与者的代码需要通过 git 上传到远端仓库中,不同的模块对应不同的 git 分支,不同模块的数据需要从远端仓库中获取.这里记录下笔者从远端仓库中获取分支数据,进行修改,最 ...
- PHP代码修改后提交,无法立即生效
今天遇到一个坑爹的问题,就是我修改了PHP代码,提交到网站根目录以后,刷新浏览器居然无法立即生效,差不多得一分钟的样子再去刷新,才会看到更改后的效果. 出现这个问题的原因,是因为手头的项目需要较高的P ...
- ecshop代码修改后提交,无法立即生效
今天帮一朋友部署一网站.成品的ecshop模版站.在搭建好xammp集成环境,导入数据库,修改配置文件后,报了一大堆错. 其中第一个是关于废弃preg_replace中/e这种用法的,因为存在漏洞,一 ...
- repo manifest xml 文件修改后提交命令
git push origin dev(本地分支):refs/for/tv/Internal_Jb910_develop_t
- git fork代码并修改胡提交到自己的git仓库
最近在参加阿里天池大数据中间件比赛(毫无头绪,打酱油中).看参赛要求,需要将官网的git工程clone下来,在此基础上做修改后提交到自己的仓库中. 由于以前并没有使用过git,所以差了比较多的资料,做 ...
- A、B同时打开一个页面进行同一条数据库记录进行修改,A修改完成后提交表单,A修改的数据保存完成后;当B也修改完成后,提交数据进行数据修改。此时B修改的内容会覆盖A修改的内容,请问如何避免?
A.B同时打开一个页面进行数据中的一条数据进行修改,A修改完成后提交表单,数据修改保存完成后B开始页面也修改完成,开始提交进行修改.此时B修改的内容会覆盖A的内容,请问如何避免? 通过搜索和我个人总结 ...
- sourcetree 修改文件后提交上去,文件丢失
提交sourcetree 修改后,图片资源提交上去了,json文件没提交上去,原因是本地finder隐藏文件.gitignore_global中把一些文件类型都隐藏了不让提交. 具体使用default ...
- idea git项目修改后无法提交 颜色都是灰色
现象: idea git项目修改后无法提交 修改后的文件提交时不显示 颜色都是灰色 分析问题出现的原因: git未识别idea下项目. 排查: 发现是因为这个项目之前是基于svn的,然后直接导入 ...
- wamp中修改后mysq数据库l闪退无法登陆解决办法
WampServer安装后密码是空的, 修改一般有三种方式: 一是通过phpMyAdmin直接修改: 二是使用WAMP的MySql控制台修改. 三是重置密码 第一种: 1 ...
随机推荐
- kinect for windows - 手势识别之一,kinect手势识别框架
何为手势识别,就是电脑认识人手的自然动作.自然动作包括摆手,握拳,双手合十等等.如果电脑能认识我们这些手势,将来的人机交互将会变得简单而有趣.这里手势不等同于某些规定的动作,比如按鼠标左键,则不属于手 ...
- Servlet、SPringMVC、Struts等防止表单反复提交的多种处理方法
第一种处理方法(非拦截器): 眼下这样的方法不建议,由于JSP规范不建议写JAVA代码.这样的能够方便另外一种处理方法的理解,另外一种方法引入拦截器的思想,原理基本一样,模仿Struts的Token机 ...
- 【企业库6】【日志应用程序块】实验2:创建和使用异步Trace Listener
Lab 2: Create and Use an Asynchronous Trace Listener 实验2:创建和使用异步Trace Listener In this lab, you will ...
- PHP 学习1- 函数之error_reporting(E_ALL ^ E_NOTICE)详细说明
在4.3.0中运行正常,在4.3.1中运行会提示Notice:Undefined varialbe:tmp_i 问题下下: 1.问题出在哪里? 2.应如何修改这段代码? 3.不改段代码,如何修改php ...
- 【在网页中获取截图数据】Chrome和Firefox下的实战经验
[转载自我在segmentfault的专栏:https://segmentfault.com/a/1190000004584071] 最近在实现一个功能,需求如下: 前提:当前页面无弹窗 页面任意位置 ...
- JavaScript编程风格--基本的格式化
缩进层级 推荐4个空格字符作为一个缩进层级. 语句结尾 推荐不要省略分号. 行的长度 最好一行不超过80个字符. 换行 在运算符后换行,下一行增加两个层级的缩进. ...
- 使用AJAX日历控件,显示某些日期(CalendarExtender)
1. The HTML Markup <div> <ajaxToolkit:ToolkitScriptManager ID="ToolkitScriptManager1&q ...
- JavaSE学习总结第05天_Java语言基础1
05.01 方法概述和格式说明 简单的说:方法就是完成特定功能的代码块 在很多语言里面都有函数的定义,函数在Java中被称为方法 格式: 修饰符返回值类型方法名(参数类型参数名1,参数类型参数名2 ...
- BZOJ 3175: [Tjoi2013]攻击装置( 匈牙利 )
黑白染成二分图, 然后不能同时选的就连边, 最大匹配数为m, t为不能放的数目, 则题目所求最大点独立集为 n*n-m-t -------------------------------------- ...
- 菜鸟初识UML
首当其冲的就是:什么是UML呢? 首先,UML 是一种可视化的面向对象的建模语言.它是一个支持模型化和软件系统开发的图形化语言,为软件开发的所有阶段提供模型化和可视化支持,包括由需求分析到规格,到构造 ...