递归循环

来源:互联网 发布:sql2008 数据库启用sa 编辑:程序博客网 时间:2024/05/17 07:49
  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  





原创粉丝点击