Foxtable(狐表)用户栏目专家坐堂 → [求助]TreeView代码救助


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

主题:[求助]TreeView代码救助

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


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
[求助]TreeView代码救助  发帖心情 Post By:2015/3/5 10:48:00 [只看该作者]

以下代码执行后,在控件“CheckBox_仅显库存”上打上勾,再点TreeView上任何节点,能正常筛选,这时,再把TreeView上的勾去掉,就弹出错误了,内容是:语法错误:“And”运算符前缺少操作数。,我把代码改了好几次,也没解决,请老师看看错在哪了,谢谢!

AfterCheckNode 事件

Dim nms As String() = {"牌号","母卷号","卷号"}  '指定生成目录树的各列
Dim qts As String() = {"'","'","'"} '指定将各列的值括起来的符号,这里都是字符型,所以都是单引号
Dim trv As WinForm.TreeView = e.Sender
Dim flt As String
Dim nd As WinForm.TreeNode
For Each nd In e.node.allNodes '清除子节点的选中标记
    nd.Checked = False
Next
nd = e.Node.ParentNode
Do While nd IsNot Nothing '清除父节点的选中标记
    nd.Checked = False
    nd = nd.ParentNode
Loop
If e.node.Text = "加载所有数据" Then
    For Each nd In trv.AllNodes
        If nd.Name <> e.Node.Name Then nd.Checked = False
    Next
    flt = "1=1"
Else
    For Each nd In trv.AllNodes
        If nd.Checked  Then
            trv.Nodes(0).Checked = False '最上面"加载所有数据" 选择框去掉
            Dim rts() As String = nd.FullPath.Split("\")
            Dim val As String = ""
            For i As Integer = 0 To rts.length - 1
                If val > "" Then
                    val = val & " And "
                End If
                val = val & nms(i) & " = " & qts(i) & rts(i) & qts(i)
            Next
            If flt > "" Then
                flt = flt & " Or (" & val & ")"
            Else
                flt = val
            End If
        End If
    Next
End If

If e.Form.Controls("CheckBox_仅显库存").checked=True Then
    Tables("工序合并表查询独立窗口_Table_工序合并表").Filter  = flt & " and [库存标记] = True"
Else Tables("工序合并表查询独立窗口_Table_工序合并表").Filter  = flt
End If

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2015/3/5 10:51:00 [只看该作者]

If e.Form.Controls("CheckBox_仅显库存").checked=True Then
    Tables("工序合并表查询独立窗口_Table_工序合并表").Filter  = iif(flt="","1=1",flt) & " And [库存标记] = True"
Else
    Tables("工序合并表查询独立窗口_Table_工序合并表").Filter  = flt
End If

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


加好友 发短信
等级:贵宾 帖子:35433 积分:178524 威望:0 精华:3 注册:2013/3/30 16:36:00
  发帖心情 Post By:2015/3/5 10:52:00 [只看该作者]

If e.Form.Controls("CheckBox_仅显库存").checked=True andalso flt <> "" Then

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


加好友 发短信
等级:版主 帖子:5246 积分:33163 威望:0 精华:8 注册:2013/1/17 21:28:00
  发帖心情 Post By:2015/3/5 10:55:00 [只看该作者]

Dim nms As String() = {"牌号","母卷号","卷号"}  '指定生成目录树的各列
Dim qts As String() = {"'","'","'"} '指定将各列的值括起来的符号,这里都是字符型,所以都是单引号
Dim trv As WinForm.TreeView = e.Sender
Dim flt As String
Dim nd As WinForm.TreeNode
For Each nd In e.node.allNodes '清除子节点的选中标记
    nd.Checked = False
Next
nd = e.Node.ParentNode
Do While nd IsNot Nothing '清除父节点的选中标记
    nd.Checked = False
    nd = nd.ParentNode
Loop
If e.node.Text = "加载所有数据" Then
    For Each nd In trv.AllNodes
        If nd.Name <> e.Node.Name Then nd.Checked = False
    Next
    flt = "1=1"
Else
    For Each nd In trv.AllNodes
        If nd.Checked  Then
            trv.Nodes(0).Checked = False '最上面"加载所有数据" 选择框去掉
            Dim rts() As String = nd.FullPath.Split("\")
            Dim val As String = ""
            For i As Integer = 0 To rts.length - 1
                If val > "" Then
                    val = val & " And "
                End If
                val = val & nms(i) & " = " & qts(i) & rts(i) & qts(i)
            Next
            If flt > "" Then
                flt = flt & " Or (" & val & ")"
            Else
                flt = val
            End If
        End If
    Next
End If
If flt = "" Then
    flt = "1 = 1"
End If
If e.Form.Controls("CheckBox_仅显库存").checked=True Then
    Tables("工序合并表查询独立窗口_Table_工序合并表").Filter  = flt & " and [库存标记] = True"
Else Tables("工序合并表查询独立窗口_Table_工序合并表").Filter  = flt
End If

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


加好友 发短信
等级:五尾狐 帖子:1105 积分:8967 威望:0 精华:0 注册:2014/10/25 11:24:00
  发帖心情 Post By:2015/3/5 12:21:00 [只看该作者]

天,三位大神帮我解答,而且用了三种方式,我好好学习一下。

再请教一个关于上面筛选树的问题。
上面的代码中有个瑕疵,筛选树有三级{"牌号","母卷号","卷号"},当我选择2级或3级时,上一级的勾不会自动打上,例如勾2级时,对应的1级应该打上勾,如果勾了3级,哪么对应的2级与1级也应该勾上,老师能帮我改下代码吗?

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


加好友 发短信
等级:版主 帖子:85326 积分:427815 威望:0 精华:5 注册:2012/10/18 22:13:00
  发帖心情 Post By:2015/3/5 14:12:00 [只看该作者]

 回复5楼,你这样不合理啊,勾选以后,下次,查询的时候,就根据勾选的结果查询了啊,肯定不正确啊。

 回到顶部