以文本方式查看主题

-  Foxtable(狐表)  (http://foxtable.net/bbs/index.asp)
--  专家坐堂  (http://foxtable.net/bbs/list.asp?boardid=2)
----  多选筛选树 问题  (http://foxtable.net/bbs/dispbbs.asp?boardid=2&id=25831)

--  作者:lsfdf
--  发布时间: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编辑过]

--  作者:布莱克朱
--  发布时间:2012/11/18 11:53:00
--  
你这个 应该进入系统就考虑不加载任何数据的  这个例子只是筛选例子
--  作者:lin_hailun
--  发布时间:2012/11/19 11:23:00
--  
 楼主,你需要分清楚什么是筛选,什么是加载。

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

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

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

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

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