以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  请教递归函数生成的目录树,编辑后的定位问题  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=72304)

--  作者:sloyy
--  发布时间:2015/7/28 1:00:00
--  请教递归函数生成的目录树,编辑后的定位问题
我用递归函数根据单位表生成了一个目录树,现在选定一个单位,在单位编辑窗的副本表中对该条记录进行编辑,然后将编辑后的数据保存到该条记录上。在保存数据后,自动重新定位到节点A,并自动展开该节点,结果出现错误.

图片点击可在新窗口打开查看此主题相关图片如下:搜狗截图20150728004949.png
图片点击可在新窗口打开查看

部门递归函数:
Dim nd As WinForm.TreeNode = Args(0)
Dim dt As DataTable = Args(1)
Dim drs As List(Of DataRow)
drs = dt.Select("[上级编码] = " & nd.Name)
For Each dr As DataRow In drs
    Dim cd As Winform.TreeNode = nd.Nodes.Add(dr("本级编码"),"[" &dr("单位编码") &"]"  &dr("单位名称"))
    Functions.Execute("部门递归函数",cd,dt)
Next

生成的目录树:

图片点击可在新窗口打开查看此主题相关图片如下:搜狗截图20150728005147.png
图片点击可在新窗口打开查看

定位展开节点:
Dim sc As Integer =Tables("单位表").Current("本级编码")
Dim tv As WinForm.TreeView = Forms("主窗口").Controls("TreeView2")
For Each nd As WinForm.TreeNode In tv.AllNodes
    If nd.DataRow("本级编码") =sc  Then
        tv.SelectedNode = nd
        nd.EnsureVisible
    End If
Next

结果在红字处出现错误:

   "未将对象引用设置到对象的实例。"
定位展开这段我是根据 LSY版主的一个例子改编的
请教各位:是不是递归函数的目录树和别的目录树不同?这句该怎么写?




--  作者:大红袍
--  发布时间:2015/7/28 9:36:00
--  

递归生成的不能用DataRow属性。

 

直接写 If nd.Name = sc Then


--  作者:sloyy
--  发布时间:2015/7/29 0:23:00
--  
好的,我试试
--  作者:sloyy
--  发布时间:2015/7/29 0:50:00
--  
测试通过,非常完美的解决了目录树编辑后的定位问题