TreeView 递归 无限级 绑定数据

TreeView怎样无限递归绑定数据(用C#语言写),谢谢。。

浏览次数:1680次 悬赏分:20 | 解决时间:2009-1-6 09:49 | 提问者:binas | 检举
数据库设计如下

50 0 军事 0
51 0 生活 0
52 1 健康菜肴 51
53 1 各国武器 50
72 0 新闻 0
73 1 国内 72
75 1 国外 72
84 0 uuu 0
85 2 aaa 52
86 3 bbb 85

最佳答案
我把我以前用的表结构先介绍下 
表主要用来保存权限分类的 
字段 PopId 权限ID 主键 
PopName 权限名字 
PostUrl 链接到的URL 
flid 父节点ID 
其中 根节点的flid为0 其他的父节点根据情况填写 

页面实现的时候 直接 添加treeview控件 
cs代码如下 
protected void Page_Load(object sender, EventArgs e) 
{ 
bindtree(PopId); 
} 
private void bindtree() 
{ 
TreeView1.Nodes.Clear(); 
AddTree(0, (TreeNode)null); 
} 
public void AddTree(int ParentID, TreeNode pNode) 
{ 
DataTable dt = new DataTable(); 
//这个是我获取数据源的代码 
dt = logbll.BindPop(); 
DataView dvTree = new DataView(dt); 
//过滤ParentID,得到当前的所有子节点 
dvTree.RowFilter = "flid = " + ParentID; 

foreach (DataRowView Row in dvTree) 
{ 
TreeNode Node = new TreeNode(); 
if (pNode == null) 
{ //添加根节点 
Node.Text = Row["PopName"].ToString(); 
TreeView1.Nodes.Add(Node); 
//Node.Expanded = true; 

AddTree(Int32.Parse(Row["PopId"].ToString()), Node); //再次递归 
} 
else 
{ //添加当前节点的子节点 
Node.Text = Row["PopName"].ToString(); 
Node.NavigateUrl = Row["PostUrl"].ToString(); 
pNode.ChildNodes.Add(Node); 
//Node.Expanded = true; 
AddTree(Int32.Parse(Row["PopId"].ToString()), Node); //再次递归 
} 
} 
}

你可以根据你的表来修改相应的字段名,下班了,没时间帮你写完整的了,代码能用,有什么问题明天再解决吧
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

万事俱备,就差一个程序员了

谢谢您,赏俺根辣条,尝尝鲜.谢

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值