Devexpress GridControl中combobox级联显示 z
http://minmin86121.blog.163.com/blog/static/4968115720143163533356/
在 使用GridControl时,可能会有需求要求某2列显示combobox控件,而且在选择第一列的值时,第2列绑定的数据源发生变化。当然这在其他地 方很容易实现,但是在gridcontrol的列中就不能用以往的思维方式进行了,因为在gridcontrol中,你只有选中这一列,它才会显示出该列 所绑定控件的特性,否则只是一个普通的lable。
基本思路:在点击第2列时才去获取第一列选中的值,然后根据该值查询出第2列的数据进行绑定。
方法/步骤
- 1
combobox 控件的创建,我是在CustomRowCellEditForEditing这个事件下处理的。(因为我所需要显示combobox的列是动态创建的,所 以需要这样创建,如果你是固定显示,直接绑定combobox点击事件就可以了。)在这个事件里面,还可以控制某一列不同行显示不同控件。(因为 Devexpress是只能设置某一列控件的属性的,不能精准到控制每个单元格中的控件)
private void gvwFetchData_CustomRowCellEditForEditing(object sender, DevExpress.XtraGrid.Views.Grid.CustomRowCellEditEventArgs e)
{
DevExpress.XtraGrid.Views.Grid.GridView view = sender as DevExpress.XtraGrid.Views.Grid.GridView;RepositoryItemComboBox cbx = new DevExpress.XtraEditors.Repository.RepositoryItemComboBox();
switch (e.Column.FieldName)
{
//case "DBConstructionID":
//cbx.Items.Clear();
// cbx.Items.AddRange(cbxConstructions.Select(c
=> new Models.ComboBoxItemTextValue<int>(c.FieldID,
c.FieldName)).ToList());
// cbx.SelectedValueChanged += new EventHandler(cbx_SelectedValueChanged);
// //e.RepositoryItem = cbx;
// gclDataOperate.RepositoryItems.Add(cbx);
// gvwFetchData.Columns["ConstructionName"].ColumnEdit = cbx;//break;
case "BuildingName"://获取该行楼盘id
string constructid = gvwFetchData.GetRowCellValue(e.RowHandle, "DBConstructionID").ToString();
//楼栋//根据楼盘查询楼栋的数据
IList<BLL.RealDataWeb.ComboBoxField>
cbxBuildings = matchData.GetBuilding(iCityID,
Convert.ToInt32(constructid));//给该行楼栋combobox绑定数据源
cbx.Items.Clear();
cbx.Items.AddRange(cbxBuildings.Select(b => new
Models.ComboBoxItemTextValue<int>(b.FieldID,
b.FieldName)).ToList());//combobox值改变后触发
cbx.SelectedValueChanged += new EventHandler(cbx_SelectedValueChanged);//下拉框选中值后,需要进行转换
cbx.ParseEditValue += new ConvertEditValueEventHandler(cbx_ParseEditValue);//指定该列控件
e.RepositoryItem = cbx;
break;
case "HouseName":
string BuindId = gvwFetchData.GetRowCellValue(e.RowHandle, "DBBuildingID").ToString();
//房号
IList<BLL.RealDataWeb.ComboBoxField> House = matchData.GetHouse(iCityID, Convert.ToInt32(BuindId));
cbx.Items.Clear();
cbx.Items.AddRange(House.Select(h => new
Models.ComboBoxItemTextValue<int>(h.FieldID,
h.FieldName)).ToList());
cbx.SelectedValueChanged += new EventHandler(cbx_SelectedValueChanged);
cbx.ParseEditValue += new ConvertEditValueEventHandler(cbx_ParseEditValue);
e.RepositoryItem = cbx;
break;
default: break;
}}

- 2
选择combobox的值时进行的处理。(例如选择楼盘后,将楼盘id存放在一隐藏列中,在点击楼栋时,获取该id,查询所需要的数据源,进行绑定)
private void cbx_SelectedValueChanged(object sender, EventArgs e)
{
BaseEdit edit = gvwFetchData.ActiveEditor;
//下拉框数据更改之后,改变级联下拉框数据
switch (gvwFetchData.FocusedColumn.FieldName)
{
//case "ConstructionName"://楼盘
//
gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["DBConstructionID"],
((ComboBoxItemTextValue<int>)edit.EditValue).SelectValue);
// gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["BuildingName"], "选择楼栋");
// gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["DBBuildingID"], 0);
// gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["HouseName"], "选择房屋");
// gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["DBHouseID"], 0);// break;
case "BuildingName"://楼栋
gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["DBBuildingID"],
((ComboBoxItemTextValue<int>)edit.EditValue).SelectValue);
gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["DBHouseName"], "选择房屋");
gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["DBHouseID"], 0);break;
case "HouseName"://房号
gvwFetchData.SetFocusedRowCellValue(gvwFetchData.Columns["DBHouseID"],
((ComboBoxItemTextValue<int>)edit.EditValue).SelectValue);
break;}


- 3
//grid中的下拉框必须要处理一下,不然会报(对象必须实现iconvertible)错误
private void cbx_ParseEditValue(object sender, ConvertEditValueEventArgs e)
{
e.Value = e.Value.ToString();
e.Handled = true;
}
Devexpress GridControl中combobox级联显示 z的更多相关文章
- 在DevExpress GridControl中添加进度条控件 z
首先可以使用 DevExpress GridControl 自带的进度条控件. 但是我要用一个方法来设置所有的单元格进度,而不是每个单元格都要设置一遍,同时我想要根据进度值不同,进度条显示不同的颜色. ...
- extjs中combobox默认显示第一个值
在进入页面时往往用户希望页面能够显示默认的内容,但是页面中会存在一些选项通过用户选择之后才会加载相应的内容.在这篇文章里面介绍了如何去设置页面中默认的内容,如combobox默认显示第一个值. 页面: ...
- Devexpress GridControl中 repositoryItemCheckEdit作为选择列以及作为显示列的使用方法
一.在gridcontrol列表控件中使用单选框作为选择列,这里有两种方式. 方式一:选择gridcontrol控件的Run Designer按钮,添加一列,设置该列的ColumnEdit为check ...
- 在DevExpress GridControl的一列中显示图片
作者:jiankunking 出处:http://blog.csdn.net/jiankunking 近期做项目的时候用到了将GridControl中一列设置为PictureEdit类型,然后通过这一 ...
- Devexpress GridControl z
http://minmin86121.blog.163.com/blog/static/4968115720144194923578/ 1 AllowNullInput=False; --Devexp ...
- DevExpress GridControl 显示外部图片
如果数据源中只包含图片的链接,如何在DevExpress GridControl的一列中显示外部图片? 要实现该功能,可通过非绑定列的方式来实现.具体实现方法如下: 1. 创建了一个非绑定列并设 ...
- winform中ComboBox实现text和value,使显示和值分开,重写text和value属性
winform的ComboBox中只能赋值text,显示和值是一样的,很多时候不能满足根本需要,熟悉B/S开发的coder最常用的就是text和value分开的,而且web下DropDownList本 ...
- DevExpress控件GridControl中的布局详解 【转】
DevExpress控件GridControl中的布局详解 [转] 2012-10-24 13:27:28| 分类: devexpress | 标签:devexpress |举报|字号 订阅 ...
- WPF界面开发:DevExpress WPF在GridControl中固定行时处理时刻
DevExpress广泛应用于ECM企业内容管理. 成本管控.进程监督.生产调度,在企业/政务信息化管理中占据一席重要之地.通过DevExpress WPF Controls,您能创建有着强大互动功能 ...
随机推荐
- 集合、拆箱、装箱、自定义集合的foreach
集合部分 参考:http://msdn.microsoft.com/zh-cn/library/0ytkdh4s(v=vs.110).aspx 集合类型是诸如哈希表.队列.堆栈.包.字典和列表等数据集 ...
- POJ1068Parencodings
http://poj.org/problem?id=1068 这个题的话就是先把给出来的一串数字转化成括号,再把括号转化成要求的,最后输出就行了 #include<cstdio> #inc ...
- lintcode 中等题:Max Points on a Line 最多有多少个点在一条直线上
题目 最多有多少个点在一条直线上 给出二维平面上的n个点,求最多有多少点在同一条直线上. 样例 给出4个点:(1, 2), (3, 6), (0, 0), (1, 3). 一条直线上的点最多有3个. ...
- Android:改变Activity切换方式
overridePendingTransition(enterAnim, exitAnim); Intent intent =new Intent(this,item2.class); startAc ...
- Entity Freamwork 6连接PostgreSql数据库
原文 Entity Freamwork 6连接PostgreSql数据库 开发环境 VS 2015 Update 1 Postgre Sql 9.4 使用过程 1.使用Nuget在项目中添加对E ...
- iOS 精确定时器
Do I need a high precision timer? Don't use a high precision timer unless you really need it. They c ...
- 通知角标(2)只用一个TextView实现
可以只用一个TextView实现通知角标,TextView的setCompoundDrawables函数可以在TextView的上,下,左,右,4条边处分别指定一个图片.见图1: 这个图片如果在角上, ...
- Java语言基本语法
Java语言基本语法 一.标识符和关键字 标识符 在java语言中,用来标志类名.对象名.变量名.方法名.类型名.数组名.包名的有效字符序列,称为“标识符”: 标识符由字母.数字.下划线.美元符号组成 ...
- 使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务
使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务 作者:Nikolay Manchev 分步构建一个跨这些平台的 ...
- @interface java注解
@Documented,@Retention,@Target,@Inherited 1. 编写自定义@Todo注解经常我们在写程序时,有时候有些功能在当前的版本中并不提供,或由于某些其它原因,有些方法 ...