C#動態綁定treeview控件

前臺只需要放一個 treeview控件就行

後臺

 

protected void Page_Load(object sender, EventArgs e)

    {
         if (!IsPostBack)
            bindTree();
    }
    private void bindTree()
    {  www.2cto.com
        DataTable dt = this.GetTreeData();
        this.FillNode(dt, null);
    }
    private void FillNode(DataTable dt, TreeNode node)
    {
        DataView dv = new DataView(dt);
        if (node == null)    //根結點
        { 
            dv.RowFilter = "parentid='0'";  //篩選到根結點的所有子節點
        }
        else  //不是根結點
        {
            dv.RowFilter = "parentid='" + node.Value + "'";   //篩選對應節點的所有子節點
        }
        foreach (DataRowView drv in dv)   //遍歷填充節點的所有子節點,如果傳入的節點node爲葉子節點,遍歷要退出,不再進行遞歸
        {
            TreeNode no = new TreeNode(drv["menuname"].ToString(), drv["menuid"].ToString());
            FillNode(dt, no);  //填充no節點的子節點
            if (node == null)
            {
                this.TreeView1.Nodes.Add(no);
            }
            else
            {
                node.ChildNodes.Add(no);
            }
        }        
    }
    private DataTable GetTreeData()
    {
        string strcnn = ConfigurationManager.ConnectionStrings["treecnn"].ConnectionString;
        using (SqlConnection sqlcnn = new SqlConnection(strcnn))
        {
            SqlCommand sqlcmm = sqlcnn.CreateCommand();
            sqlcmm.CommandText = "select * from MenuTree order by parentid,menuorder";
            SqlDataAdapter da = new SqlDataAdapter(sqlcmm);
            DataSet ds = new DataSet();
            da.Fill(ds);
            return ds.Tables[0];
        }
發佈了19 篇原創文章 · 獲贊 5 · 訪問量 6萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章