遍历所有子节点,逐个判断。
比如判断选中的节点
Dim tr As WinForm.TreeView
tr = Forms("窗口1").Controls("TreeView1")
Dim td As WinForm.TreeNode = tr.SelectedNode
dim lst as new list(of string)
for each dd as WinForm.TreeNode in td.nodes
if lst.contains(dd.text) then
msgbox("重复节点:" & dd.text)
else
lst.add(dd.text)
end if
next
2楼的是事后检查
我的要求是 同一节点下 不能重复 跨节点可以重复 如图

此主题相关图片如下:下载.png

Dim strnum As String=e.node.fullname.replace("\",".")
'检查是否有重复名称
Dim nochongfu As Boolean
nochongfu=True
Dim treename As String
treename=e.newtext
''
'判断重复
Dim trv As WinForm.TreeView = e.Form.Controls("TreeView1")
For Each nd As WinForm.TreeNode In trv.AllNodes
If nd.FullName <> e.Node.FullName AndAlso nd.Text = e.NewText Then
messagebox.show("有重复名称","信息提示")
e.cancel=True
nochongfu=False
End If
Next
这样的话 不管任何节点下 都不能重复了 不符合我的要求 麻烦帮我看一下
……
Dim trv As WinForm.TreeView = e.Sender
Dim ns = trv.nodes
If e.node.ParentNode IsNot Nothing Then
ns = e.node.ParentNode.nodes
End If
For Each nd As WinForm.TreeNode In ns
If nd.FullName <> e.Node.FullName AndAlso nd.Text = e.NewText Then
messagebox.show("有重复名称","信息提示")
e.cancel=True
……