private void LoadList()
{
if (trvGroup.Nodes.Count == 0)
{
lvContact.Clear();
return;
}
if (trvGroup.SelectedNode.Index >=0)
{
string strGroup = trvGroup.SelectedNode.Text;
try
{
lvContact.Clear();
lvContact.Columns.Add("姓名", 100);
lvContact.Columns.Add("工作单位", 150);
lvContact.Columns.Add("联系电话", 100);
lvContact.Columns.Add("电子邮箱", 150);
SqlConnection conn = new SqlConnection(strConn);
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
cmd.CommandText = "select 编号,姓名,工作单位,联系电话,电子邮箱 from 联系人 where 组别='" + strGroup + "'";
conn.Open();
SqlDataReader sdr = cmd.ExecuteReader();
while (sdr.Read())
{
ListViewItem lvi = new ListViewItem();
lvi.Text = sdr["姓名"].ToString();
lvi.SubItems.Add(sdr["工作单位"].ToString());
lvi.SubItems.Add(sdr["联系电话"].ToString());
lvi.SubItems.Add(sdr["电子邮箱"].ToString());
lvi.Tag = sdr["编号"];
lvi.ImageIndex = 0;
lvContact.Items.Add(lvi);
}
sdr.Close();
conn.Close();
}
catch
{ }
}
}
private void trvGroup_AfterSelect(object sender, TreeViewEventArgs e)
{
LoadList();
}
private void trvGroup_MouseDown(object sender, MouseEventArgs e)
{
if ((sender as TreeView) != null)
{
trvGroup.SelectedNode = trvGroup.GetNodeAt(e.X, e.Y);
}
}
private void lvContact_SelectedIndexChanged(object sender, EventArgs e)
{
}
我就是在treeview中但一个节点,然后把它对应在数据库中的内容显示在一个listview中。但是结果listview一直显示第一个节点的内容,单击之后没有反应。
求大神解救啊,小弟最近刚刚自学C#,很多东西还不太明白。
你一会儿用trvGroup
一会儿用treeview
,是不是多个TreeView的事件关联到同一个处理过程中了?
LoadList()是从trvGroup对应的树控件来获取组信息,而treeview_MouseDown中使用的是treeview对应的树控件,2个不一致,所以不管如何操作,listview值不会变的
此外
if (trvGroup.SelectedNode.Index >= 0)这个判断也存在问题,应该采用if (trvGroup.SelectedNode!=null)
楼上两位大大,实在抱歉,是小弟粘贴的时候出了错,现在重新粘贴了一遍。我只用了一个treeview控件,名字是trvGroup,但是问题还在。求各路大神解救啊。