Foxtable(狐表)用户栏目专家坐堂 → 多选筛选树 问题


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

主题:多选筛选树 问题

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


加好友 发短信
等级:童狐 帖子:200 积分:2454 威望:0 精华:0 注册:2011/12/14 20:48:00
多选筛选树 问题  发帖心情 Post By:2012/11/18 0:34:00 [只看该作者]

帮助里有个多选筛选树的例子,有个情况,当所有的节点都不选择时,会加载所有的数据,
我想不加载任何数据,这个该如何判断一下呢,因为实际运用时,数据量太大,直接卡死

Dim trv As WinForm.TreeView = e.Sender
Dim
flt As String
For
Each nd As WinForm.TreeNode In e.node.Nodes '同步子节点选中状态
    nd.Checked = e.Node.
Checked

Next
If
e.node.ParentNode IsNot Nothing Then '去掉父节点选中状态
    e.node.ParentNode.Checked =
False

End
If
For
Each nd As WinForm.TreeNode In trv.AllNodes
    If nd.Level > 0 AndAlso nd.ParentNode.Checked Then
'
如果父节点选中
        Continue For
'
跳过此节点,处理下一结点
    End If
    If nd.Checked Then
        If flt > "" Then
            flt = flt & " Or " 
'
注意用or而不是And
        End If
        If nd.Level = 0 Then
'
注意下面的条件都要用括号括起来
            flt = flt &
"(
产品 = '" & nd.Text & "')"
       
Else
            flt = flt & "( 产品 = '" & nd.ParentNode.Text & "' And 客户 = '" & nd.Text & "')"
        End If
    End If   

Next
Tables
("订单").Filter = flt

[此贴子已经被作者于2012-11-18 0:34:43编辑过]

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


加好友 发短信
等级:三尾狐 帖子:623 积分:3897 威望:0 精华:0 注册:2011/8/3 22:13:00
  发帖心情 Post By:2012/11/18 11:53:00 [只看该作者]

你这个 应该进入系统就考虑不加载任何数据的  这个例子只是筛选例子

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


加好友 发短信
等级:狐神 帖子:6708 积分:34304 威望:0 精华:11 注册:2012/8/18 23:10:00
  发帖心情 Post By:2012/11/19 11:23:00 [只看该作者]

 楼主,你需要分清楚什么是筛选,什么是加载。

 筛选,是针对已经加载的内容。

 加载,是针对数据库的数据。

 如果打开项目的时候不希望加载任何数据可以看一下帮助。

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

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

 回到顶部