增加根节点

procedure loadUser(Sender: TObject; qry1, qry2: TADOQuery; tree: TspSkinTreeView; var treeNode1, treeNode2, treeNode3: TTreeNode);
//tree: TspSkinTreeView为皮肤控件类型

procedure TfrmUserMgr.loadUser(Sender: TObject; qry1, qry2: TADOQuery; tree: TspSkinTreeView; var treeNode1, treeNode2, treeNode3: TTreeNode);
begin
with qry1 do
begin
Close;
SQL.Clear;
SQL.Add('select * from user');
Open;
end;

Case qry1.fieldbyname('user_rights').AsInteger of
0:
begin
treeNode1 := tree.Items.Add(nil,'管理员');
with qry2 do
begin
Close;
SQL.Clear;
SQL.Add('select * from user where user_rights=0');
Open;
end;
while not qry2.Eof do
begin
tree.Items.Add(treeNode1,qry2.fieldbyname('user_name').AsString);
qry2.Next;
end;
end;

1:
begin
treeNode2:=tree.Items.Add(nil,'操作员');
with qry2 do
begin
Close;
SQL.Clear;
SQL.Add('select * from user where user_rights=1');
Open;
end;
while not qry2.Eof do
begin
tree.Items.Add(treeNode2,qry2.fieldbyname('user_name').AsString);
qry2.Next;
end;
end;

2:
begin
treeNode3:=tree.Items.Add(nil,'普通用户');
with qry2 do
begin
Close;
SQL.Clear;
SQL.Add('select * from user where user_rights=2');
Open;
end;
while not qry2.Eof do
begin
tree.Items.Add(treeNode3,qry2.fieldbyname('user_name').AsString);
qry2.Next;
end;
end;
qry1.next;
end;
end;
要实现
0---|管理员----|用户a
| |用户b
| |用户c
1---操作员----|用户d
| |用户e
| |用户f
2---|普通用户--|用户g
应该如何修改代码?现在能显示所有内容,但是比如操作员有N个用户,那么就会出现N个操作员的根节点,哪位大虾帮忙?
采纳率:56% 11级 2013.11.17
begin
treeNode2:=tree.Items.Add(nil,'操作员');
with qry2 do
begin
Close;
SQL.Clear;
SQL.Add('select * from user where user_rights=1');
Open;
end;
while not qry2.Eof do
begin
// 注意这里,只要把Add改成AddChild就可以了 tree.Items.AddChild(treeNode2,qry2.fieldbyname('user_name').AsString);
qry2.Next;
end;
end;

其它类同,
TTreeView.Items.Add是添加 根结点
TTreeView.Items.AddChild是在第一个 参数指示的 节点下添加一个节点
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值