Foxtable(狐表)用户栏目专家坐堂 → 想能像FT的窗体管理那样上下调整节点顺序


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

主题:想能像FT的窗体管理那样上下调整节点顺序

帅哥哟,离线,有人找我吗?
李睿涵
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:780 积分:5756 威望:0 精华:0 注册:2012/10/21 7:57:00
想能像FT的窗体管理那样上下调整节点顺序  发帖心情 Post By:2016/4/26 8:50:00 [只看该作者]

做了个年级、班级的树,想能够像FT的窗体管理那样自由调整节点顺序
把控件打好了,希望能帮助实现一下


图片点击可在新窗口打开查看此主题相关图片如下:qq截图20160426084758.png
图片点击可在新窗口打开查看
 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:树.table



 回到顶部
帅哥哟,离线,有人找我吗?
大红袍
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:贵宾 帖子:39310 积分:196782 威望:0 精华:1 注册:2015/4/25 9:23:00
  发帖心情 Post By:2016/4/26 9:37:00 [只看该作者]

年级上移

 

Dim tr As WinForm.TreeView = e.Form.Controls("TreeView1")
Dim nd As WinForm.TreeNode = tr.SelectedNode
If nd.Index = 0 Then
    msgbox("无法再上移")
Else
    Dim pnd As WinForm.TreeNode = tr.Nodes(nd.Index-1)
    Dim s1 As Double = DataTables("表a").find("年级 = '" & pnd.text & "'")("_Sortkey")
    Dim s2 As Double = DataTables("表a").find("年级 = '" & nd.text & "'")("_Sortkey")
    DataTables("表a").replacefor("_Sortkey", s2, "年级 = '" & pnd.text & "'")
    DataTables("表a").replacefor("_Sortkey", s1, "年级 = '" & nd.text & "'")
    nd.MoveUp
End If

 

 

 下载信息  [文件大小:   下载次数: ]
图片点击可在新窗口打开查看点击浏览该文件:树.table


 回到顶部
帅哥哟,离线,有人找我吗?
李睿涵
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:780 积分:5756 威望:0 精华:0 注册:2012/10/21 7:57:00
  发帖心情 Post By:2016/4/26 10:31:00 [只看该作者]

谢谢

年级的上移好用,班级的上移不行,窗体关闭后重开,会恢复之前的排序


 回到顶部
帅哥哟,离线,有人找我吗?
大红袍
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:贵宾 帖子:39310 积分:196782 威望:0 精华:1 注册:2015/4/25 9:23:00
  发帖心情 Post By:2016/4/26 10:32:00 [只看该作者]

两种,测试都没问题。

 回到顶部
帅哥哟,离线,有人找我吗?
李睿涵
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:780 积分:5756 威望:0 精华:0 注册:2012/10/21 7:57:00
  发帖心情 Post By:2016/4/26 11:26:00 [只看该作者]

加了弹窗,发现S1  S2  2个值相同

我数据删了重新添加 就可以了

 

 


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


 回到顶部
帅哥哟,离线,有人找我吗?
大红袍
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:贵宾 帖子:39310 积分:196782 威望:0 精华:1 注册:2015/4/25 9:23:00
  发帖心情 Post By:2016/4/26 11:29:00 [只看该作者]

Dim tr As WinForm.TreeView = e.Form.Controls("TreeView1")
Dim nd As WinForm.TreeNode = tr.SelectedNode
If nd.Index = 0 Then
    msgbox("无法再上移")
Else
    Dim pnd As WinForm.TreeNode = nd.ParentNode.nodes(nd.Index-1)
    Dim s1 As Double = DataTables("表a").find("年级 = '" & pnd.ParentNode.text & "' and 班级 = '" & pnd.Text & "'")("_Sortkey")
    Dim s2 As Double = DataTables("表a").find("年级 = '" & nd.ParentNode.text & "' and 班级 = '" & nd.text & "'")("_Sortkey")
    If s1 = s2 Then
        s1 -= 0.1
        s2 += 0.1
    End If

    DataTables("表a").replacefor("_Sortkey", s2, "年级 = '" & pnd.ParentNode.text & "' and 班级 = '" & pnd.Text & "'")
    DataTables("表a").replacefor("_Sortkey", s1, "年级 = '" & nd.ParentNode.text & "' and 班级 = '" & nd.Text & "'")
   
    nd.MoveUp
End If

 回到顶部
帅哥哟,离线,有人找我吗?
李睿涵
  7楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:780 积分:5756 威望:0 精华:0 注册:2012/10/21 7:57:00
  发帖心情 Post By:2016/4/26 11:38:00 [只看该作者]

这个代码补充得好,谢谢!

 回到顶部
帅哥哟,离线,有人找我吗?
李睿涵
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:780 积分:5756 威望:0 精华:0 注册:2012/10/21 7:57:00
  发帖心情 Post By:2016/4/26 12:12:00 [只看该作者]

领导,还有个问题

就是节点会重复出现,该怎么规避?

 

 


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

 回到顶部
帅哥哟,离线,有人找我吗?
大红袍
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:贵宾 帖子:39310 积分:196782 威望:0 精华:1 注册:2015/4/25 9:23:00
  发帖心情 Post By:2016/4/26 12:16:00 [只看该作者]

你表A的数据,相同年级的数据,必须放在一起,不能分开的。


 回到顶部
帅哥哟,离线,有人找我吗?
大红袍
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:贵宾 帖子:39310 积分:196782 威望:0 精华:1 注册:2015/4/25 9:23:00
  发帖心情 Post By:2016/4/26 12:17:00 [只看该作者]


 回到顶部
总数 12 1 2 下一页