Foxtable(狐表)用户栏目专家坐堂 → [求助]TreeView复选时,点击过快出现问题


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

主题:[求助]TreeView复选时,点击过快出现问题

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


加好友 发短信
等级:幼狐 帖子:120 积分:1157 威望:0 精华:0 注册:2019/8/10 1:23:00
[求助]TreeView复选时,点击过快出现问题  发帖心情 Post By:2020/1/27 18:05:00 [显示全部帖子]

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


图片点击可在新窗口打开查看此主题相关图片如下:gif 2020-01-27 17-55-59.gif
图片点击可在新窗口打开查看

如果点击速度快,会出现选中的和表不一致


代码:
Dim trv As WinForm.TreeView = e.Form.Controls("TreeView1")
Dim flt As String
For Each nd As WinForm.TreeNode In e.node.AllNodes  '同步子节点选中状态
    If nd.FullPath.StartsWith(e.node.FullPath) Then
        nd.Checked = e.node.Checked
    End If
Next

For Each nd As WinForm.TreeNode In trv.AllNodes
      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.Text & "')"
            'flt = flt & "( 产品 = '" & nd.ParentNode.Text & "' And 客户 = '" & nd.Text & "')"
        End If
    End If    
Next
Tables("人员信息").Filter = flt


[此贴子已经被作者于2020/1/27 20:20:18编辑过]

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


加好友 发短信
等级:幼狐 帖子:120 积分:1157 威望:0 精华:0 注册:2019/8/10 1:23:00
  发帖心情 Post By:2020/1/27 19:58:00 [显示全部帖子]

没有,是在AfterCheckNode

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


加好友 发短信
等级:幼狐 帖子:120 积分:1157 威望:0 精华:0 注册:2019/8/10 1:23:00
  发帖心情 Post By:2020/1/28 20:16:00 [显示全部帖子]

能不能加个双击复选框,不能勾选取消复选框的代码,即双击复选框无任何变化?
如果可行,该怎么写?

 回到顶部