#region 利用递归遍历树控件节点判断某个节点是否已存在
/// <summary>
/// 利用递归遍历树控件节点判断某个节点是否已存在
/// </summary>
/// <param name="control">树控件(TreeView或TreeList)</param>
/// <param name="nodeName">要判断是否已存在的节点的名称</param>
/// <param name="nodeExisting">判断结果(true:已存在;false:不存在)</param>
/// <param name="treeNode">要遍历的节点对象(默认为null值时,遍历的是顶级节点)</param>
public static void TraverseTreeNode(Control control, String nodeName, ref Boolean nodeExisting, object treeNode = null)
{
if (control is TreeView)//判断当前传入控件是否为TreeView控件
{
TreeView treeView = control as TreeView;
TreeNode treeViewNode = treeNode as TreeNode;
if (treeNode == null)//判断当前传入节点对象是否为null,是则证明为第一次调用该方法
{
if (treeView.Nodes.Count > 0)
{
nodeExisting = treeView.Nodes.ContainsKey(nodeName);//判断控件的一级节点中是否存在当前传入的节点名称对象
if (nodeExisting)
return;
else
{
//如果当前传入的节点名称没有找到对应的节点,则循环遍历一级节点同时判断每个一级节点是否有子节点
//如果有则调用方法本身将当前子节点传入方法,用来判断当前子节点中是否存在节点名称对应的对象
foreach (TreeNode childrenNode in treeView.Nodes)
{
if (childrenNode.Nodes.Count > 0)
TraverseTreeNode(control, nodeName, ref nodeExisting, childrenNode);
}
}
}
}
else
{
if (treeViewNode.Nodes.Count > 0)
{
//判断当前传入节点的子节点中是否存在当前传入的节点名称对应的节点对象
nodeExisting = treeViewNode.Nodes.ContainsKey(nodeName);
if (nodeExisting)
return;
else
{
//如果当前传入的节点名称没有找到对应的节点,则循环遍历当前传入节点中的子节点同时判断每个子节点是否有子节点
//如果有则调用方法本身将当前子节点传入方法,用来判断当前子节点中是否存在节点名称对应的对象
foreach (TreeNode childrenNode in treeViewNode.Nodes)
{
if (childrenNode.Nodes.Count > 0)
TraverseTreeNode(control, nodeName, ref nodeExisting, childrenNode);
}
}
}
}
}
else if (control is TreeList)
{
}
}
#endregion