FineUI 官方论坛

标题: 动态生成树控件 [打印本页]

作者: 破风    时间: 2012-3-6 09:38
标题: 动态生成树控件
就是利用一个表里面有ID和父ID根据这两个关系进行一个关联之后,显示在页面上以树的形式
作者: dim_$lift    时间: 2012-3-6 17:19
我也想弄这个,起初想把xml文件存在数据库里直接读出来生成树,结果 textarea 在修改带有"<>"符合时就报错,又是404 405等等。。唉
作者: 沧海为水    时间: 2012-3-6 19:02
完全可以实现啊
作者: 破风    时间: 2012-3-7 09:04
大神  求赐教啊~~~
作者: 沧海为水    时间: 2012-3-7 19:35
protected void BindTreeData()
        {
            
            OleDbConnection myConnection = new OleDbConnection(ConfigurationManager.AppSettings["ConnectionString_ms"]);
            string selectCmd = "select fjd_dm ParentId ,jd_dm Id ,jd_mc text , gnmk_ljmc NavigateUrl from qx_gnmk_gnmb order by jd_order ";
            DataSet dSet1 = new DataSet();

            OleDbDataAdapter myCommand = new OleDbDataAdapter(selectCmd, myConnection);
            myCommand.Fill(dSet1, "UserData");
            dSet1.Relations.Add("TreeRelation", dSet1.Tables[0].Columns["Id"], dSet1.Tables[0].Columns["ParentId"]);

            foreach (DataRow row in dSet1.Tables[0].Rows)
            {
                if (row.IsNull("ParentId"))
                {
                    ExtAspNet.TreeNode node = new ExtAspNet.TreeNode();
                    node.Text = row["Text"].ToString();
                    node.Expanded = true;
                    treeMenu.Nodes.Add(node);
                    ResolveSubTree(row, node);
                }
            }
           
        }

        private void ResolveSubTree(DataRow dataRow, ExtAspNet.TreeNode treeNode)
        {
            DataRow[] rows = dataRow.GetChildRows("TreeRelation");
            if (rows.Length > 0)
            {
                treeNode.Expanded = true;
                foreach (DataRow row in rows)
                {
                    ExtAspNet.TreeNode node = new ExtAspNet.TreeNode();
                    node.Text = row["Text"].ToString();
                    node.NavigateUrl = row["NavigateUrl"].ToString();
                    treeNode.Nodes.Add(node);

                    ResolveSubTree(row, node);
                }
            }
        }

作者: 破风    时间: 2012-3-8 09:50
不知道 大神是否用过linq 我是用的linq哦~~~好像不太一样




欢迎光临 FineUI 官方论坛 (https://fineui.com/BBS/) Powered by Discuz! X3.4