递归循环

  1. using System.Web;  
  2. using System.Web.Security;  
  3. using System.Web.UI;  
  4. using System.Web.UI.WebControls;  
  5. using System.Web.UI.WebControls.WebParts;  
  6. using System.Web.UI.HtmlControls;  
  7.   
  8. public partial class _Default : System.Web.UI.Page  
  9. {  
  10.     DataView dv;  
  11.     DataTable dt;  
  12.   
  13.     protected void Page_Load(object sender, EventArgs e)  
  14.     {  
  15.   
  16.         if (!Page.IsPostBack)  
  17.         {  
  18.     //数据库执行查询的方法就不写了。  
  19.             Operator op = new Operator();  
  20. //这里执行的是:select * from tabmenu  
  21.             dt = op.Query();  
  22.             //第一次加载时调用方法传参   
  23.             CreateTree(0, null, dt, this.TreeView1);  
  24.             this.TreeView1.ExpandAll();  
  25.         }  
  26.     }  
  27.   
  28.     /// <summary>   
  29.     /// 创建一个树   
  30.     /// </summary>   
  31.     /// <param name="parentID">父ID</param>   
  32.     /// <param name="node">节点</param>   
  33.     /// <param name="dt">DataTable</param>   
  34.     /// <param name="treeView">TreeView的名称</param>   
  35.     public void CreateTree(int parentID, TreeNode node, DataTable dt, TreeView treeView)  
  36.     {  
  37.         //实例化一个DataView dt = 传入的DataTable   
  38.         dv = new DataView(dt);  
  39.         //筛选(相当于select * from tabMenu where menuParentID = 传入的 parentID)   
  40.         dv.RowFilter = "[menuParentID]=" + parentID;  
  41.   
  42.         //用foreach遍历dv   
  43.         foreach (DataRowView row in dv)  
  44.         {  
  45.             //第一次加载时为空   
  46.             if (node == null)  
  47.             {  
  48.                 //创建根节点   
  49.                 TreeNode root = new TreeNode();  
  50.                 //必须与数据库的对应   
  51.                 root.Text = row["menuName"].ToString();  
  52.                 root.Value = row["menuID"].ToString();  
  53.                 //添加根节点   
  54.                 this.TreeView1.Nodes.Add(root);  
  55.                 //递归调用方法本身   
  56.                 CreateTree(int.Parse(row["menuID"].ToString()), root, dt, treeView);  
  57.   
  58.             }  
  59.             else  
  60.             {  
  61.                 //添加子节点   
  62.                 TreeNode childNode = new TreeNode();  
  63.                 childNode.Text = row["menuName"].ToString();  
  64.                 childNode.Value = row["menuID"].ToString();  
  65.                 node.ChildNodes.Add(childNode);  
  66.                 CreateTree(int.Parse(row["menuID"].ToString()), childNode, dt, treeView);  
  67.   
  68.             }  
  69.         }  
  70.   
  71.     }  
  72. }  












  1. create table tabMenu  
  2. (  
  3.    menuID int identity(1,1) primary key,--自动编号  
  4.    menuParentID int not null,--上级菜单的编号  
  5.    menuName varchar(20) not null,--菜单名称  
  6.    menuUrl varchar(20) not null,--菜单地址  
  7.    menuImage varchar(20) not null, --图片地址  
  8.    menuTarget varchar(20) not null,--打开方式  
  9. )  
  10. go  
  11. --0表示根节点  
  12. insert into tabMenu   
  13. values(0,'xx后台管理','','','')  
  14.   
  15. --1子节点  
  16. insert into tabMenu   
  17. values(1,'学生管理','','','')  
  18.   
  19. insert into tabMenu   
  20. values(1,'班级管理','','','')  
  21. --2级节点  
  22. insert into tabMenu   
  23. values(2,'S1','','','')  
  24.   
  25. insert into tabMenu   
  26. values(2,'S2','','','')  
  27.   
  28. insert into tabMenu   
  29. values(2,'s3','','','')  
  30. --3级节点  
  31.   
  32. insert into tabMenu   
  33. values(3,'S1','','','')  
  34.   
  35. insert into tabMenu   
  36. values(3,'S2','','','')  
  37.   
  38. insert into tabMenu   
  39. values(3,'s3','','','')  
  40.   
  41. insert into tabMenu   
  42. values(4,'Ccc','','','')  
  43.   
  44. insert into tabMenu   
  45. values(5,'bbb,'','','')  
  46.   
  47. insert into tabMenu   
  48. values(6,'fff','','','')  
  49. --  
  50. insert into tabMenu   
  51. values(7,'stu1','','','')  
  52.   
  53. insert into tabMenu   
  54. values(8,'stu2','','','')  
  55.   
  56. insert into tabMenu   
  57. values(9,'stu1','','','')  
  58. select * from tabMenu  
  59. go  





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值