On Error GoTo ErrForm_Load
Dim db As Database, Rst As Recordset, nodCurrent As Node
Dim objTree As TreeView, strText As String, nodRoot As Node
Dim bk As String
Set db = CurrentDb
Set Rst = db.OpenRecordset("SwitchboardItems", dbOpenDynaset, dbReadOnly)
Set objTree = Me!xTree.Object
' 查找第一个上级
Rst.FindFirst "[ItemNumber] Is Null"
' 向TREEVIEW装入数据
Do Until Rst.NoMatch
' 取得科目名称
strText = Rst![ItemText]
' TREEVIEW第一层.
Set nodCurrent = objTree.Nodes.Add(, , "a" & Rst!ID, strText, 1, 2)
' 装记录位置存入变量.
bk = Rst.Bookmark
' 用递归过程加入子节点(调用)
AddChildren nodCurrent, Rst
' 返回原位
Rst.Bookmark = bk
' 查找下一个上级
Rst.FindNext "[ItemNumber] Is Null"
Loop
'==================================================================
'子过程,加入子节点及孙节点
'==================================================================
Sub AddChildren(nodBoss As Node, Rst As Recordset)
On Error GoTo ErrAddChildren
Dim nodCurrent As Node
Dim objTree As TreeView, strText As String, bk As String
' 变量.
Set objTree = Me!xTree.Object
' 查找第一个子节点
Rst.FindFirst "[ItemNumber] =" & Mid(nodBoss.Key, 2)
' 装入数据
Do Until Rst.NoMatch
' 取得科目名称.
strText = Rst![ItemText]
' 加入子节咪.
Set nodCurrent = objTree.Nodes.Add(nodBoss, tvwChild, "a" & Rst!ID, strText, 1, 2)
' 保存位置
bk = Rst.Bookmark
' 装入下层节点
AddChildren nodCurrent, Rst
' 返回并继续查找
Rst.Bookmark = bk
' 查找下一个
Rst.FindNext "[ItemNumber]=" & Mid(nodBoss.Key, 2)
Loop
ExitAddChildren:
Exit Sub
ErrAddChildren:
MsgBox Err.Description, vbCritical, "AddChildren Error:"
Resume ExitAddChildren
End Sub 作者: zjhzyubin 时间: 2019-2-26 11:06
上传图片作者: roych 时间: 2019-2-26 15:32