设为首页收藏本站Access中国

Office中国论坛/Access中国论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

返回列表 发新帖
楼主: 三个太阳
打印 上一主题 下一主题

[宏/菜单/工具栏] 代码正确运行了,但treeview为何没有正常加载数据呢?

[复制链接]
1#
发表于 2015-7-8 14:01:44 | 显示全部楼层
缺乏子节点的添加操作,供参考。
http://www.office-cn.net/thread-119551-1-1.html
请留意里面的AddChildNode函数。
以下是kingkang的实例,里面使用了递归算法,相对更复杂些许。
http://www.office-cn.net/thread-66634-1-1.html
2#
发表于 2015-7-8 16:20:49 | 显示全部楼层
三个太阳 发表于 2015-7-8 15:38
谢谢roych老师,能帮学生指点一下我的代码的漏洞在哪儿吗?理论上我感觉确实没问题。

键值(key)有问题,请对比你的代码。
  1. Private Sub Command1_Click()
  2. Dim rs As Recordset
  3. Set rs = CurrentDb.OpenRecordset("select * from 学生表")
  4. On Error Resume Next '此句是用来处理下面循环里面Index语句的
  5. ActiveXCtl0.nodes.Add , , "学生管理", "学生管理"
  6. With rs
  7. Do Until .EOF
  8.         If ActiveXCtl0.nodes(.Fields(2)).Index < 0 Then
  9.         ActiveXCtl0.nodes.Add "学生管理", 4, "K" & .Fields(2), .Fields(2)
  10.         End If
  11.         If ActiveXCtl0.nodes(.Fields(3)).Index < 0 Then
  12.         ActiveXCtl0.nodes.Add "K" & .Fields(2), 4, "KK" & .Fields(3), .Fields(3)
  13.         End If
  14.         ActiveXCtl0.nodes.Add "KK" & .Fields(3), 4, "KKK" & .Fields(1), .Fields(1)
  15. .MoveNext
  16. Loop
  17. End With
  18. End Sub
复制代码
3#
发表于 2015-7-8 16:48:07 | 显示全部楼层
本帖最后由 roych 于 2015-7-8 16:52 编辑
三个太阳 发表于 2015-7-8 16:44
难道是节点的K值不能和节点的text值一样?

key值是唯一的。树控件也是根据key值来判断节点的从属关系的。事实上,也只有在忽略掉错误提示时,这段代码才可以运行,否则还是回出错的。
4#
发表于 2015-7-8 17:05:17 | 显示全部楼层
风中漫步 发表于 2015-7-8 16:53
好,斑竹.
看了这段代码,觉的这个地方拿不准:
       If ActiveXCtl0.nodes(.Fields(3)).Index < 0 Then ...

确实存在这个问题。
还是应该改为递归才行。不然的话,这么movenext几下,全都乱套了。
5#
发表于 2015-7-8 17:31:09 | 显示全部楼层
三个太阳 发表于 2015-7-8 17:28
谢谢老师,我的代码初步设计确实有问题!以下是修改好的:
Private Sub Command1_Click()
Dim rs As Re ...

幸亏也只有三层啊。要是多几层,写起来估计也不是一件太愉快的事情了
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|站长邮箱|小黑屋|手机版|Office中国/Access中国 ( 粤ICP备10043721号-1 )  

GMT+8, 2024-5-4 23:31 , Processed in 0.105518 second(s), 28 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表