FineUI 官方论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

本论坛已关闭(禁止注册、发帖和回复)
请移步 三石和他的朋友们

FineUI首页 WebForms - MVC & Core - JavaScript 常见问题 - QQ群 - 十周年征文活动

FineUI(开源版) 下载源代码 - 下载空项目 - 获取ExtJS - 文档 在线示例 - 版本更新 - 捐赠作者 - 教程

升级到 ASP.NET Core 3.1,快、快、快! 全新ASP.NET Core,比WebForms还简单! 欢迎加入【三石和他的朋友们】(基础版下载)

搜索
查看: 4191|回复: 5
打印 上一主题 下一主题

动态生成树控件

[复制链接]
跳转到指定楼层
楼主
发表于 2012-3-6 09:38:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
就是利用一个表里面有ID和父ID根据这两个关系进行一个关联之后,显示在页面上以树的形式
沙发
发表于 2012-3-6 17:19:49 | 只看该作者
我也想弄这个,起初想把xml文件存在数据库里直接读出来生成树,结果 textarea 在修改带有"<>"符合时就报错,又是404 405等等。。唉
板凳
发表于 2012-3-6 19:02:15 | 只看该作者
完全可以实现啊
地板
 楼主| 发表于 2012-3-7 09:04:29 | 只看该作者
大神  求赐教啊~~~
5#
发表于 2012-3-7 19:35:05 | 只看该作者
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);
                }
            }
        }
6#
 楼主| 发表于 2012-3-8 09:50:16 | 只看该作者
不知道 大神是否用过linq 我是用的linq哦~~~好像不太一样
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|FineUI 官方论坛 ( 皖ICP备2021006167号-1 )

GMT+8, 2024-11-24 04:27 , Processed in 0.043241 second(s), 17 queries , Gzip On.

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表