Foxtable(狐表)用户栏目专家坐堂 → 关于更改目录树数据问题


  共有3872人关注过本帖树形打印复制链接

主题:关于更改目录树数据问题

帅哥,在线噢!
裴保民
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
关于更改目录树数据问题  发帖心情 Post By:2020/3/15 9:45:00 [显示全部帖子]

修改或添加目录树项目时怎么控制不让有重复字段呢?

 回到顶部
帅哥,在线噢!
裴保民
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/3/15 21:07:00 [显示全部帖子]

保存按钮代码如下?
Dim dt As DataTable = DataTables("收入分类")
Dim dic As New Dictionary(of Integer, Integer)
Dim prevLevel As Integer = 0
Dim idxs As String = "-1,"
For Each nd As WinForm.TreeNode In e.Form.Controls("srflTreeView").AllNodes
    If nd.Level = 0 AndAlso dic.count > 0 Then
        Dim temp = dic(0)
        dic.Clear
        dic.Add(0, temp)
    End If
    
    If dic.ContainsKey(nd.Level) = False Then
        dic.Add(nd.Level, 1)
    Else
        dic(nd.Level) = dic(nd.Level) + 1
    End If
    For i As Integer = nd.level + 1 To prevLevel
        dic(i) = 0
    Next
    
    prevLevel = nd.Level
    Dim ndr As DataRow
    If nd.DataRow IsNot Nothing Then
       'ndr = dt.Find("SRID = '" & nd.DataRow("SRID"))
       ndr = dt.Find(" SRID = '" & nd.DataRow("SRID") & " '") '字符列使用单引号
         'Dim idx As Integer=t.findrow("机具条码= '" & str & "' and _Identify <> " & t.current("_Identify"))
    Else
        ndr = dt.AddNew
    End If
    idxs &= "'" & ndr("SRID") & "',"
    Dim str As String = ""
    For i As Integer = 0 To nd.Level
        str &= format(dic(i), "000") & "."
    Next
    ndr("收入分类代码") = str.TrimEnd(".")
    ndr("收入目录") = nd.Text
Next
dt.DeleteFor("SRID not in (" & idxs & ")")
 dt.Save

想要的结果如下图?怎么修改代码?

图片点击可在新窗口打开查看此主题相关图片如下:截图00.jpg
图片点击可在新窗口打开查看







 回到顶部
帅哥,在线噢!
裴保民
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/3/15 23:25:00 [显示全部帖子]

如果有重复怎么禁止离开节点呢?


还有一个为题在AfterEditNode事件中下面的代码可以查出重复值,如果在按钮中编写代码,怎么查呢?如果重复,选中该节点,
Dim trv As WinForm.TreeView=e.Form.Controls("zcflTreeView")
For Each nd As WinForm.TreeNode In trv.AllNodes
    If nd.FullName <> e.Node.FullName AndAlso nd.Text = e.NewText Then
        msgbox("重复")       
  e.Cancel = True
  trv.Select()
  trv.BeginEdit()
    End If
Next

[此贴子已经被作者于2020/3/15 23:39:34编辑过]

 回到顶部
帅哥,在线噢!
裴保民
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/3/15 23:50:00 [显示全部帖子]

还有一个为题在AfterEditNode事件中下面的代码可以查出重复值,如果在按钮中编写代码,怎么查呢?如果重复,选中该节点,
Dim trv As WinForm.TreeView=e.Form.Controls("zcflTreeView")
For Each nd As WinForm.TreeNode In trv.AllNodes
    If nd.FullName <> e.Node.FullName AndAlso nd.Text = e.NewText Then
        msgbox("重复")       
  e.Cancel = True
  trv.Select()
  trv.BeginEdit()
    End If
Next

 回到顶部
帅哥,在线噢!
裴保民
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/3/16 9:14:00 [显示全部帖子]

写在按钮中判断是错误的没有e.NewText


图片点击可在新窗口打开查看此主题相关图片如下:截图01.jpg
图片点击可在新窗口打开查看

[此贴子已经被作者于2020/3/16 9:15:26编辑过]

 回到顶部
帅哥,在线噢!
裴保民
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/3/16 11:52:00 [显示全部帖子]

Dim trv As WinForm.TreeView = e.Form.Controls("zcflTreeView")
If trv.SelectedNode IsNot Nothing Then
    Dim pd As WinForm.TreeNode = trv.SelectedNode
    Dim Index As Integer = 1
    If pd.Nodes.count >= 1 Then
        Index = cint(pd.Nodes(pd.nodes.count - 1).name) + 1
    End If
    Dim nd As WinForm.TreeNode = pd.Nodes.Add(index,"新节点")
  ' MessageBox.Show("请为【新节点】重新命名","提示",MessageBoxButtons.OK)
    trv.SelectedNode = nd
    trv.Select
    trv.BeginEdit
Forms("支出类型赋值编辑窗体").Open
End If
这个是再加一个下级节点,怎么修改为增加同级节点呢?弄了半天没弄好

 回到顶部
帅哥,在线噢!
裴保民
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:2007 积分:12788 威望:0 精华:0 注册:2017/4/3 15:01:00
  发帖心情 Post By:2020/3/16 13:58:00 [显示全部帖子]

保存不了代码

图片点击可在新窗口打开查看此主题相关图片如下:截图02.jpg
图片点击可在新窗口打开查看


 回到顶部