- 在线时间
- 0 小时
- 最后登录
- 2005-2-2
- 注册时间
- 2004-5-13
- 听众数
- 0
- 收听数
- 0
- 能力
- 0 分
- 体力
- 64 点
- 威望
- 0 点
- 阅读权限
- 20
- 积分
- 20
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1
- 主题
- 1
- 精华
- 0
- 分享
- 0
- 好友
- 0
升级   15.79% 该用户从未签到
 |
我想实现这样的功能,遍历tree中的节点。树是单位的部门结构树,节点是其中部门,已经添加好的。我想遍历树中所有节点,如果没有子节点说明是单位中的最小部门,然后查询改部门的员工并添加到该部门以下。下面的代码,一直都出错,好像是内存读取错误。请帮忙,三拜~~~; m; i9 k7 q2 H7 \5 n* \( h! m/ o
procedure Trs.TreeView1Click(Sender: TObject);! A* ?9 F2 i' V' P/ e0 S
var node: TTreeNode;' L: j$ _" Z/ A/ `% g& \3 w% Q' F V
strnode:string;" p$ T, D. u3 u3 w. _
label ok;
& o+ A5 \ @0 C% w label haschild;
; C: f2 V$ M2 { label nextnode;
l% `/ l/ M5 o& e M7 Ybegin
- n0 Y( E7 Z" @& f8 D9 u6 S node:=treeview1.TopItem;
/ V" ?! g, C bhaschild: node:=getfirstchild(node);, P0 n5 I) L! E% N
strnode:=node.Text;
; V2 x& y h% I: x dm.qtree.Close;- J3 f2 y- A- T- K) ~
dm.qtree.SQL.Clear;0 p; [) g9 l& K
dm.qtree.SQL.Text:='select empname from empbasic where depid='+''''+strnode+'''';" A1 r6 f i% v2 }' s) q
dm.qtree.Open; //取得该部门下所有员工姓名
( \) ~2 O2 g1 M7 a2 F; F if not(dm.qtree.IsEmpty) then //如果记录非空(即该部门下有员工)' r" ~" L9 i/ ?! z/ n, u; `
begin //将所有员工姓名都作为子节点添加# R: X% M0 k% }- d
repeat
. H1 w9 j# n: y b8 v strnode:=dm.qtree.fieldbyname('empname').AsString;
$ p, g. h& @* d treeview1.Items.AddChild(node,strnode);
. D' [7 n9 w. b. L" W- d dm.qtree.Next;
. }8 x, B- ^+ D ?, R until dm.qtree.Eof;0 n+ e& y- E. \ H+ Q3 b/ \6 B
end;; _+ F: R/ s7 E' V0 H) N
if not(node.IndexOf(node.Parent)=node.Parent.Count -1) then //如果当前节点不是同级节点最后一个& V; v! S/ `7 u# X7 s2 ~
begin
1 e& I) d2 T. H9 x" d: X/ \. `nextnode: node:=node.getNextSibling; //取得下一个同级节点. [# A7 f& d3 j9 i% I5 b
goto haschild;
0 f9 s' A" l9 O& J# k9 k end. I! D/ z2 `7 D1 Y$ t2 C
else
' C4 X* Z2 X! k begin
; p1 Q5 p7 p+ R, E if node.Index =treeview1.Items.Count then goto ok
' ~8 g9 T% p. V1 t* i: q else goto nextnode;
" s5 J2 W* K; ]2 x# E* o, {; @3 B end;
9 x8 n j+ c! [: \* Jok:null;
5 Q( o6 b8 [$ x c8 n2 ^end; |
zan
|