我有两个组合框(比如cbo_zone& cbo_floor),它们将表作为数据源
private void load_cbo_zone()
{
clz_Common_References ccr = new clz_Common_References ();
DataTable dt_zone = ccr.get_zone_detail();
cbo_zone.DataSource = dt_zone;
cbo_zone.ValueMember = "ID";
cbo_zone.DisplayMember = "zone";
cbo_zone.SelectedIndex = -1;
}
`
private void load_cbo_floor()
{
int ID_zone_ref = Convert.ToInt16(cbo_zone.SelectedValue);
clz_Common_References ccr = new clz_Common_References();
DataTable dt_flr = ccr.get_floor_data_fr_Ref_IDZone(ID_zone_ref);
cbo_floor.DataSource = dt_flr;
cbo_floor.DisplayMember = "Floor";
cbo_floor.ValueMember = "ID";
cbo_floor.SelectedIndex = -1;
}
`我写了代码来更新cbo_floor如下。
private void cbo_zone_SelectionChangeCommitted(object sender, EventArgs e)
{
load_cbo_floor();
}
现在我需要更新cbo_zone&单击datagridview的数据行时的cbo_floor。
int ref_area_id, ref_floor_id, ref_zone_id;
int.TryParse(dt_issued_mat.Rows[0][11].ToString(), out ref_area_id);
DataTable dt_area_detail = ccr.get_area_data_fr_area_id(ref_area_id);
int.TryParse(dt_area_detail.Rows[0][2].ToString(), out ref_floor_id);
DataTable dt_floor_detail = ccr.get_floor_data_fr_floor_id(ref_floor_id);
int.TryParse(dt_floor_detail.Rows[0][2].ToString(), out ref_zone_id);
DataTable dt_zone_detail = ccr.get_zone_data_fr_zone_id(ref_zone_id);
之后使用
cbo_zone.Text = dt_zone_detail.Rows[0][1].ToString();
cbo_floor.Text = dt_floor_detail.Rows[0][1].ToString();
我能够在组合框中显示值,但是一旦我尝试获取cbo_floor.SelectedValue代码就不起作用。
然后我可以通过使用
获得相关的SelectedIndexint index = cbo_zone.FindString(dt_zone_detail.Rows[0][1].ToString());
cbo_zone.SelectedIndex = index ;
仍然是组合框没有显示任何内容" cbo_zone.SelectedValue"没有按'吨 显示一个value.my目标是获取cbo_floor.SelectedValue。 请帮忙。
答案 0 :(得分:0)
而不是cbo_zone.Text = dt_zone_detail.Rows[0][1].ToString();
cbo_floor.Text = dt_floor_detail.Rows[0][1].ToString();
使用
cbo_zone.Items.Add( dt_zone_detail.Rows[0][1].ToString());
cbo_floor.Items.Add ( dt_floor_detail.Rows[0][1].ToString());
答案 1 :(得分:0)
首先使用索引不是一个好主意。你有价值,使用它们。使用索引会给您带来麻烦。
cbo_zone.SelectedValue = myValue.ToString();//find the value from your data
其次,为了选择楼层,您需要先填写相关值,因为它已经有最后一个选择的数据。
load_cbo_floor();
cbo_floor.SelectedValue = myValue.ToString();//find the value from your data