Foxtable(狐表)用户栏目专家坐堂 → treeview问题


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

主题:treeview问题

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


加好友 发短信
等级:一尾狐 帖子:481 积分:3258 威望:0 精华:0 注册:2015/6/2 8:33:00
treeview问题  发帖心情 Post By:2016/4/20 9:15:00 [只看该作者]


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


DataTables("SQL_wdjbxxb").Load
DataTables("SQL_user").Load
Dim tr As WinForm.TreeView = e.Form.Controls("TreeView1")
Dim nd1 As WinForm.TreeNode
Dim nd2 As WinForm.TreeNode
Dim nd3 As WinForm.TreeNode
Dim nd4 As WinForm.TreeNode
Dim nd5 As WinForm.TreeNode
Dim nd6 As WinForm.TreeNode
Dim nd7 As WinForm.TreeNode
nd1 = Tr.Nodes.Add("我的文档","我的文档","Folder.ico")
nd2 = Tr.Nodes.Add("我的回收站","我的回收站","Folder.ico")
nd3 = Tr.Nodes.Add("公有文档","公有文档","Folder.ico")
nd4 = Tr.Nodes.Add("共享文档","共享文档","Folder.ico")
   nd4.Nodes.Add("按类型分类")
   nd4.Nodes.Add("按部门分类")
   nd4.Nodes.Add("按群组分类")
nd5 = Tr.Nodes.Add("最近操作文档","最近操作文档","Folder.ico")
nd6 = Tr.Nodes.Add("最近收到文档","最近收到文档","Folder.ico")
nd7 = Tr.Nodes.Add("文档查询","文档查询","Folder.ico")

老师,这是现在的样子,,我希望在“类型分类”下建立1层子节点,按type来分;部门分类”下建立2层子节点,department|username来分;群组分类”下建立2层子节点,group|username来分,这些属性都是某一张表格里的列属性,请问如何实现。

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


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


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


加好友 发短信
等级:一尾狐 帖子:481 积分:3258 威望:0 精华:0 注册:2015/6/2 8:33:00
  发帖心情 Post By:2016/4/20 19:08:00 [只看该作者]

'---在各表名下生成目录树节点
e.Sender.StopRedraw
Dim pnd As WinForm.TreeNode = e.Node
If e.Node.level = 1 Then  '如果是表名节点
    e.Node.Nodes.Clear  '清空原有节点
    Dim tbName As String = e.Node.Name
    Dim dr As DataRow = DataTables("表B").Find("表名 = '" & tbName & "'")
    If dr IsNot Nothing Then
        Dim Cols As String = dr("目录树列")
        Dim Cols_sort As String = Cols.replace("|",",")
        
        Dim nds As new List(Of WinForm.TreeNode)
        For i As Integer = 0 To Cols.Split("|").Length
            nds.Add(e.Node)
        Next
        If nds.Count > 2 Then
            For Each arys As String() In DataTables(tbName).GetValues(Cols, "", Cols_sort)
                Dim flag As Boolean = False
                For i As Integer = 0 To arys.Length - 1
                    If nds(i+1).Name <> arys(i) OrElse flag Then
                        flag = True
                        nds(i+1) = nds(i).Nodes.Add(arys(i))
                    End If
                Next
            Next
        Else
            For Each arys As String In DataTables(tbName).GetValues(Cols, "", Cols_sort)
                nds(1) = nds(0).Nodes.Add(arys)
            Next
        End If
        
        e.Node.Expand
    End If
End If
e.Sender.ResumeRedraw


老师,上面代码在哪里设置节点的属性,比如图片,标题

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


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

 

nds(i+1) = nds(i).Nodes.Add(arys(i))

nds(i+1).IconFile = "d:\test.ico"

 

 

nds(1) = nds(0).Nodes.Add(arys)

nds(1).IconFile = "d:\test.ico"


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


加好友 发短信
等级:一尾狐 帖子:481 积分:3258 威望:0 精华:0 注册:2015/6/2 8:33:00
  发帖心情 Post By:2016/4/20 20:38:00 [只看该作者]

老师,字节怎么换算,M G kb 字节 怎么写代码换算

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


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

1G = 1024 M

1M = 1024 K

1K = 1024 B

 

FileInfo里面得到的是B


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


加好友 发短信
等级:一尾狐 帖子:481 积分:3258 威望:0 精华:0 注册:2015/6/2 8:33:00
  发帖心情 Post By:2016/4/20 21:33:00 [只看该作者]

Dim w_type As String
w_type = e.Form.Controls("ComboBox1").value

Dim dlg As New OpenFileDialog '定义一个新的OpenFileDialog
  dlg.Filter="Excel文件|*.xls|Word文件|*.doc|Access文件|*.mdb|图档|*.bmp;*.jpg;*.gif|文本文件|*.txt" '设置筛选器
If dlg.ShowDialog = DialogResult.Ok Then '如果用户单击了确定按钮
MessageBox.Show("您已选择了1份文档,这些文档将被导入到万盛文管服务器,在导入之前,您可能需要设置这些文档的类型以及共享权限!","提示",MessageBoxButtons.YesNo,MessageBoxIcon.Question)
End If

Dim lujing = dlg.FileName
Dim ifo As new FileInfo(lujing)
Dim w_CreationTime As String
Dim w_LastWriteTime As String
Dim w_LastAccessTime As String
Dim w_ReadOnly As String
Dim w_Hidden As String
Dim w_Path As String
Dim w_Length As String
Dim w_Name As String
Dim w_Extension As String
    w_CreationTime = ifo.CreationTime
    w_LastWriteTime = ifo.LastWriteTime 
    w_LastAccessTime = ifo.LastAccessTime
    w_ReadOnly = ifo.ReadOnly
    w_Hidden = ifo.Hidden
    w_Path = ifo.Path
    w_Length = ifo.Length
    w_Name = ifo.Name
    w_Extension = ifo.Extension
Dim W_L As String
    Select Case w_Length
       Case w_Length<1024
         W_L = w_Length+"KB"
       Case 1024<=w_Length<1048576
         W_L = w_Length/1024+"MB"
       Case Else
          W_L = w_Length/1048576+"GB"
    End Select

With MainTable
Dim cmd As New SQLCommand
cmd.C
cmd.CommandText = "Insert Into {wdjbxxb} ([wdmc],[wdlx],[wddx],[cjsj],[xgsj]) Values ('"
cmd.CommandText = cmd.CommandText & w_Name & "','" & w_type & "','" & w_Length & "','" & w_CreationTime & "','" & w_LastWriteTime & "')"
cmd.ExecuteNonQuery
DataTables("SQL_wdjbxxb").Save()
Tables("SQL_wdjbxxb").Current.Load()
End With

老师,出现问题1:“从字符串“GB”到类型“Double”的转换无效。
          去掉GB那段代码的转化     出现问题2:“未将对象引用到实例化“ 但内容已经填到数据库字段里

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


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

 存放的时候,为什么要存放 xxxGB 这样?如果确实要存放,你就要用字符类型的列

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


加好友 发短信
等级:一尾狐 帖子:481 积分:3258 威望:0 精华:0 注册:2015/6/2 8:33:00
  发帖心情 Post By:2016/4/21 12:06:00 [只看该作者]

老师,好的谢谢,属性我们可以出来了;


 

nds(i+1) = nds(i).Nodes.Add(arys(i))

nds(i+1).IconFile = "d:\test.ico"

 

 

nds(1) = nds(0).Nodes.Add(arys)

nds(1).IconFile = "d:\test.ico"



但是我们想进一步完善一下,上列中如何做到设置指定节点的属性(图标、标题等等)。
谢谢!
[此贴子已经被作者于2016/4/21 12:07:45编辑过]

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


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

看不懂你想问什么

 

nds(i+1).IconFile = "d:\test.ico"

nds(i+1).Text = "aabbcc"

 

http://www.foxtable.com/help/topics/0895.htm

 


 回到顶部
总数 46 1 2 3 4 5 下一页