我做的节点添加可能只是符合我的要求,并不一定适合所有的人。
我的树是从数据库中查询,然后自己递归添加的。
当我给树添加节点的时候,如果重新绑定数据库的话,会造成树的节点收缩,开始我的解决办法就是保存上次
点击的节点,然后重新查询的时候再张开。
SearchNode(jiedian, TreeView1.Nodes[0]);
jiedian未上次打开的节点的Value值
private void SearchNode(string SearchName, TreeNode node)
{
TreeView1.Nodes[0].Expand();
if (node.Value.IndexOf(SearchName) >= 0)
{
while (node.Parent != null)
{
node.Expand();
node = node.Parent;
}
}
else
{
for (int i = 0; i < node.ChildNodes.Count; i++)
{
SearchNode(SearchName, node.ChildNodes[i]);
}
}
}
这样做的确定很多,浪费资源为了一个节点的添加和更改,查询整个数据库,但有优点是可以及时得到最新的数据,当多人操作的时候,这是很重要的。
我下面做的是不重新查询数据可只是在本地对树进行添加节点。
我这里只给一个删除的例子,其他的大同小异了
public static void DeleteTree(TreeNodeCollection node, DataTable dt)
{
bool flag = false;
DataView dv = new DataView(dt);
foreach (DataRowView drv in dv)
{
for (int i = 0; i < node.Count; i++)
{
if (TreeGridBind.returnKey(node[i].Value).Trim().Equals(drv["id"].ToString().Trim()))
{
node.RemoveAt(i);
flag = true;
break;
}
else
{
DeleteTree(node[i].ChildNodes, dt);
}
}
if (flag)
break;
}
}