ASP.NET遞迴添加樹節點

來源:互聯網
上載者:User

表設計:

id        title         parentid

1         asp.net   0
2         c#           0
3         c#_0       2
4         c#_1       3
5         c#_2       4

 

頁面中添加一個TreeView控制項

 

寫添加節點方法:

  private void AddNode(int id, TreeNode parentnode)
    {
        string sql = "select * from menu";//sql 語句
        DataTable table = DB.GetDB(sql);//擷取資料

        DataView view = new DataView(table);//把表資料添加到自訂視圖中

        view.RowFilter = "parentid="+id;//設定視圖查詢條件

        foreach (DataRowView row in view)//遍曆視圖中資料
        {
            TreeNode node = new TreeNode();

            node.Text = row[1].ToString();
            int newid = Convert.ToInt32(row[0]);
           
            if (parentnode != null)
            {
                node.Expanded = false;
                parentnode.ChildNodes.Add(node);
                AddNode(newid, node);//遞迴尋找節點
            }
            else
            {
                TreeView1.Nodes.Add(node);
                AddNode(newid, node);
            }
           
        }
    }

 

DB類中GetDB()方法:

 public static SqlConnection sqlconn()
    {
        string sqlconnstr = "database=menutree;data source=.;uid=sa;pwd=123";

        SqlConnection conn = new SqlConnection(sqlconnstr);
        return conn;
    }

    public static DataTable GetDB(string sql)
    {
        SqlConnection connection = sqlconn();
        SqlCommand comm = new SqlCommand(sql, connection);

        SqlDataAdapter ad = new SqlDataAdapter(comm);
        DataTable table = new DataTable();
        ad.Fill(table);
        return table;
    }

 

 

調用代碼:

 

 protected void Page_Load(object sender, EventArgs e)
    {
      
        if (!IsPostBack)
        {
            TreeView1.Nodes.Clear();
            AddNode(0, (TreeNode)null);
        }
    }

完成!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.