repositoryItemGridLookUpEdit联动问题请教

qq_15347949 2017-06-22 09:59:35
目前遇到的问题就是当我选第二行第一行数据就会改变,求各位老师帮我解答一下

 public partial class Form1 : Form
{
DataTable dtg = new DataTable();
DataTable dtd = new DataTable();
public Form1()
{
InitializeComponent();
Load += Form1_Load;
}

void Form1_Load(object sender, EventArgs e)
{
gridView1.CustomRowCellEditForEditing += gridView1_CustomRowCellEditForEditing;
//gridView1.CustomRowCellEdit += gridView1_CustomRowCellEdit;


DataTable dt = new DataTable();
dt.Columns.Add("FSBH", typeof(string));
dt.Columns.Add("LXBH", typeof(string));
gridControl1.DataSource = dt;

dtg.Columns.Add("LXBH", typeof(string));
dtg.Columns.Add("LXMC", typeof(string));
DataRow rowg = dtg.NewRow();
rowg["LXBH"] = "01";
rowg["LXMC"] = "136路";
dtg.Rows.Add(rowg);

dtd.Columns.Add("LXBH", typeof(string));
dtd.Columns.Add("LXMC", typeof(string));
DataRow rowd = dtd.NewRow();
rowd["LXBH"] = "05";
rowd["LXMC"] = "火车站";
dtd.Rows.Add(rowd);

}

void gridView1_CustomRowCellEdit(object sender, DevExpress.XtraGrid.Views.Grid.CustomRowCellEditEventArgs e)
{
switch (e.Column.FieldName)
{
case "LXBH":
string FSMC = gridView1.GetRowCellValue(e.RowHandle, "FSBH").ToString();



break;


}







}

void gridView1_CustomRowCellEditForEditing(object sender, DevExpress.XtraGrid.Views.Grid.CustomRowCellEditEventArgs e)
{


switch (e.Column.FieldName)
{
case "LXBH":
string FSMC = gridView1.GetRowCellValue(e.RowHandle, "FSBH").ToString();
if (FSMC != null && FSMC != "")
{
if (FSMC!="" && FSMC=="公交")
{
RepositoryItemLookUpEdit lookupg = (gridColumn2.ColumnEdit as RepositoryItemLookUpEdit);

lookupg.DataSource = dtg;
lookupg.ValueMember = "LXBH";
lookupg.DisplayMember = "LXMC";
lookupg.NullText = string.Empty;

lookupg.EditValueChanged += new EventHandler(lookup_EditValueChanged);
lookupg.ParseEditValue += new DevExpress.XtraEditors.Controls.ConvertEditValueEventHandler(lookup_ParseEditValue);
e.RepositoryItem = lookupg;

}
else if (FSMC!="" && FSMC=="地铁")
{
RepositoryItemLookUpEdit lookupd = (gridColumn2.ColumnEdit as RepositoryItemLookUpEdit);


lookupd.DataSource = dtd;
lookupd.ValueMember = "LXBH";
lookupd.DisplayMember = "LXMC";
lookupd.NullText = string.Empty;

lookupd.EditValueChanged += new EventHandler(lookup_EditValueChanged);
lookupd.ParseEditValue += new DevExpress.XtraEditors.Controls.ConvertEditValueEventHandler(lookup_ParseEditValue);
e.RepositoryItem = lookupd;
}


}

break;
default: break;

}
}

void lookup_ParseEditValue(object sender, DevExpress.XtraEditors.Controls.ConvertEditValueEventArgs e)
{
if (e.Value != null)
e.Value = e.Value.ToString();
else
e.Value = "";
e.Handled = true;

}

void lookup_EditValueChanged(object sender, EventArgs e)
{
DevExpress.XtraEditors.BaseEdit edit = gridView1.ActiveEditor;
switch (gridView1.FocusedColumn.FieldName)
{
case "LXBH":
System.Diagnostics.Debug.Write(edit.EditValue);
gridView1.SetFocusedRowCellValue(gridView1.Columns["LXBH"], edit.EditValue);
break;
}
}
}
...全文
758 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_15347949 2017-06-23
  • 打赏
  • 举报
回复
引用 8 楼 duanzi_peng 的回复:
[quote=引用 7 楼 qq_15347949 的回复:] [quote=引用 6 楼 duanzi_peng 的回复:] [quote=引用 5 楼 qq_15347949 的回复:] [quote=引用 3 楼 duanzi_peng 的回复:] 第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
求版主指导一下[/quote] 换成同一个数据源,只绑定一次数据。[/quote] 本来是两个datatable 的 现在合并到一个数据源上 能够筛选出来吗 比如说:下拉选择地铁的时候只显示地铁的数据[/quote] 不可以,就算可以筛选,不还要重新设置DataSource供选择,也会影响第一行。总之,同一列必须合并数据。[/quote] 不合并数据源,那就不能实现分类联动效果了
  • 打赏
  • 举报
回复
引用 9 楼 qq_15347949 的回复:
[quote=引用 8 楼 duanzi_peng 的回复:] [quote=引用 7 楼 qq_15347949 的回复:] [quote=引用 6 楼 duanzi_peng 的回复:] [quote=引用 5 楼 qq_15347949 的回复:] [quote=引用 3 楼 duanzi_peng 的回复:] 第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
求版主指导一下[/quote] 换成同一个数据源,只绑定一次数据。[/quote] 本来是两个datatable 的 现在合并到一个数据源上 能够筛选出来吗 比如说:下拉选择地铁的时候只显示地铁的数据[/quote] 不可以,就算可以筛选,不还要重新设置DataSource供选择,也会影响第一行。总之,同一列必须合并数据。[/quote] 不合并数据源,那就不能实现分类联动效果了 [/quote] 不合并数据的话可以在你上边的CustomRowCellEdit事件中,动态设置RepositoryItem 为不同的RepositoryItemLookUpEdit,这个事件是针对单元格编辑触发的。
qq_15347949 2017-06-22
  • 打赏
  • 举报
回复
引用 3 楼 duanzi_peng 的回复:
第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
该怎么去改!
  • 打赏
  • 举报
回复
第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
shoppo0505 2017-06-22
  • 打赏
  • 举报
回复
应该是你edit第一列的时候,更新的第二列绑定的数据源,然后点击第二列的时候,刷新了数据。 可以能这个函数gridView1_CustomRowCellEdit刷新了每一行的数据,建议判断一行e.RowIndex,看看更新的哪一行,对于这一行进行操作。
qq_15347949 2017-06-22
  • 打赏
  • 举报
回复
有人吗 求指教
  • 打赏
  • 举报
回复
引用 7 楼 qq_15347949 的回复:
[quote=引用 6 楼 duanzi_peng 的回复:] [quote=引用 5 楼 qq_15347949 的回复:] [quote=引用 3 楼 duanzi_peng 的回复:] 第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
求版主指导一下[/quote] 换成同一个数据源,只绑定一次数据。[/quote] 本来是两个datatable 的 现在合并到一个数据源上 能够筛选出来吗 比如说:下拉选择地铁的时候只显示地铁的数据[/quote] 不可以,就算可以筛选,不还要重新设置DataSource供选择,也会影响第一行。总之,同一列必须合并数据。
qq_15347949 2017-06-22
  • 打赏
  • 举报
回复
引用 6 楼 duanzi_peng 的回复:
[quote=引用 5 楼 qq_15347949 的回复:] [quote=引用 3 楼 duanzi_peng 的回复:] 第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
求版主指导一下[/quote] 换成同一个数据源,只绑定一次数据。[/quote] 本来是两个datatable 的 现在合并到一个数据源上 能够筛选出来吗 比如说:下拉选择地铁的时候只显示地铁的数据
  • 打赏
  • 举报
回复
引用 5 楼 qq_15347949 的回复:
[quote=引用 3 楼 duanzi_peng 的回复:] 第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
求版主指导一下[/quote] 换成同一个数据源,只绑定一次数据。
qq_15347949 2017-06-22
  • 打赏
  • 举报
回复
引用 3 楼 duanzi_peng 的回复:
第二次 lookupd的DataSource 都改变了,当然会影响第一行,因为改变的是同一个列的DataSource
求版主指导一下

111,097

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧