主要使用递归实现,数据库结构:

最终样式:

 1protected void Page_Load(object sender, EventArgs e)
 2    {
 3        if (!Page.IsPostBack)
 4        {
 5            BindDrpClass();
 6        }
 7    }
 8    //绑定顶级分类
 9    private void BindDrpClass()
10    {
11        Bll.Class classSystem = new Bll.Class();
12        DataTable dt = classSystem.GetClassList("").Tables[0];
13        ddlClass.Items.Clear();
14        ddlClass.Items.Add(new ListItem("添加根栏目","0"));
15        DataRow[] drs = dt.Select("ParentID= " + 0);
16
17        foreach (DataRow dr in drs)
18        {
19            string classid = dr["ClassID"].ToString();
20            string classname = dr["ClassName"].ToString();
21            //顶级分类显示形式
22            classname = "╋" + classname;
23
24            ddlClass.Items.Add(new ListItem(classname, classid));
25            int sonparentid = int.Parse(classid);
26            string blank = "├";
27            //递归子分类方法
28            BindNode(sonparentid, dt, blank);
29        }
30        ddlClass.DataBind();
31    }
32    //绑定子分类
33    private void BindNode(int parentid, DataTable dt, string blank)
34    {
35        DataRow[] drs = dt.Select("ParentID= " + parentid);
36
37        foreach (DataRow dr in drs)
38        {
39            string classid = dr["ClassID"].ToString();
40            string classname = dr["ClassName"].ToString();
41
42            classname = blank + classname;
43            ddlClass.Items.Add(new ListItem(classname, classid));
44
45            int sonparentid = int.Parse(classid);
46            string blank2 = blank + "─";
47
48            BindNode(sonparentid, dt, blank2);
49        }
50    }

源码下载:

http://files.cnblogs.com/chensubo/RecursionDemo.rar

改造过的函数

// <asp:DropDownList ID="editparentid"  runat="server" ></asp:DropDownList>


   /// <summary>
    ///  加载页面 
    ///</summary>
    protected void Page_Load(object sender, EventArgs e)
    {
       BindDrpClass(editparentid);}

/// <summary>


/// 创建树
    /// </summary>
    public void BindDrpClass(DropDownList ddlClass)
    {
        DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, "select * from NT_Clcs_ClientType").Tables[0];
        ddlClass.Items.Clear();
        ddlClass.Items.Add(new ListItem("添加根栏目", "0"));
        DataRow[] drs = dt.Select("ParentID= " + 0);
        foreach (DataRow dr in drs){
            string classid = dr["Cc_ID"].ToString();
            string classname = dr["Cc_Name"].ToString();
            //顶级分类显示形式
            classname = "╋" + classname;             ddlClass.Items.Add(new ListItem(classname, classid));
            int sonparentid = int.Parse(classid);
            string blank = "├";
            //递归子分类方法
            BindNode(ddlClass, sonparentid, dt, blank);
        }
        editparentid.DataBind();
    }
    /// <summary>
    /// 创建树结点
    /// </summary>
    private void BindNode(DropDownList ddlNode, int parentid, DataTable dt, string blank)
    { 
        DataRow[] drs = dt.Select("ParentID= " + parentid);
        foreach (DataRow dr in drs){
            string classid = dr["Cc_ID"].ToString();
            string classname = dr["Cc_Name"].ToString();
            classname = blank + classname;
            ddlNode.Items.Add(new ListItem(classname, classid));
            int sonparentid = int.Parse(classid);
            string blank2 = blank + "─";
            BindNode(ddlNode,sonparentid, dt, blank2);
        }
    }

二次改造做成一个通用的类 调用  如:  new DrpGradingList("select * from dbo.NT_Clcs_ClientType ", "Cc_Name", "Cc_ID", defValue).BindDrpClass(ddl);


    /// <summary>
    /// DropDownList 树形显示
    /// </summary>
    public class DrpGradingList
    {
        private string Sql = "";
        private string Text = "";
        private string Value = "";
        private string defValue = "";
        private string parentId = "ParentID";
        /// <summary>
        ///  DropDownList 树形显示
        /// </summary>
        /// <param name="sql">SQL语句</param>
        /// <param name="text">显示的文本( 数据库字段)</param>
        /// <param name="value">显示的文本对应的值( 数据库字段)</param>
        public DrpGradingList(string sql, string text, string value, string defvalue)
        {
            this.Sql = sql;
            this.Text = text;
            this.Value = value;
            this.defValue = defvalue;
        }
        /// <summary>
        ///  DropDownList 树形显示
        /// </summary>
        /// <param name="sql">SQL语句</param>
        /// <param name="text">显示的文本( 数据库字段)</param>
        /// <param name="value">显示的文本对应的值( 数据库字段)</param>
        public DrpGradingList(string sql, string text, string value, string defvalue,string pid)
        {
            this.Sql = sql;
            this.Text = text;
            this.Value = value;
            this.defValue = defvalue;
            this.parentId = pid;
        }
        /// <summary>
        /// 创建树
        /// </summary>
        public void BindDrpClass(DropDownList ddlClass)
        {
            DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, Sql).Tables[0];
            ddlClass.Items.Clear();
            ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
            DataRow[] drs = dt.Select(""+this.parentId+"= " + 0);
            foreach (DataRow dr in drs)
            {
                string classid = dr[this.Value].ToString();
                string classname = dr[this.Text].ToString();
                //顶级分类显示形式
                classname = "╋" + classname;                 ListItem itme = new ListItem();
                itme.Text=classname;
                itme.Value=classid;
                if (itme.Value.Equals(this.defValue))
                    itme.Selected = true;                 ddlClass.Items.Add(itme);
                int sonparentid = int.Parse(classid);
                string blank = "├";
                //递归子分类方法
                BindNode(ddlClass, sonparentid, dt, blank);
            }
            ddlClass.SelectedIndex = ddlClass.Items.IndexOf(ddlClass.Items.FindByValue(this.defValue));
            ddlClass.DataBind();
        }
        /// <summary>
        /// 创建树  ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
        /// </summary>
        public void BindDrpClass(DropDownList ddlClass, bool defItem)
        {
            DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, Sql).Tables[0];
            ddlClass.Items.Clear();
            if (defItem){
                ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
            }
            DataRow[] drs = dt.Select("" + this.parentId + "= " + 0);
            foreach (DataRow dr in drs)
            {
                string classid = dr[this.Value].ToString();
                string classname = dr[this.Text].ToString();
                //顶级分类显示形式
                classname = "╋" + classname;                 ListItem itme = new ListItem();
                itme.Text = classname;
                itme.Value = classid;
                if (itme.Value.Equals(this.defValue))
                    itme.Selected = true;                 ddlClass.Items.Add(itme);
                int sonparentid = int.Parse(classid);
                string blank = "├";
                //递归子分类方法
                BindNode(ddlClass, sonparentid, dt, blank);
            }
            ddlClass.SelectedIndex = ddlClass.Items.IndexOf(ddlClass.Items.FindByValue(this.defValue));
            ddlClass.DataBind();
        }
        public void BindDrpClass(DropDownList ddlClass, bool defItem,string parentIdefVale)
        {
            if (parentIdefVale.Length == 0) parentIdefVale = "0";
            DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, Sql).Tables[0];
            ddlClass.Items.Clear();
            if (defItem)
            {
                ddlClass.Items.Add(new ListItem("顶级栏目", "0"));
            }
            DataRow[] drs = dt.Select("" + this.parentId + "= " + parentIdefVale);
            foreach (DataRow dr in drs)
            {
                string classid = dr[this.Value].ToString();
                string classname = dr[this.Text].ToString();
                //顶级分类显示形式
                classname = "╋" + classname;                 ListItem itme = new ListItem();
                itme.Text = classname;
                itme.Value = classid;
                if (itme.Value.Equals(this.defValue))
                    itme.Selected = true;                 ddlClass.Items.Add(itme);
                int sonparentid = int.Parse(classid);
                string blank = "├";
                //递归子分类方法
                BindNode(ddlClass, sonparentid, dt, blank);
            }
            ddlClass.SelectedIndex = ddlClass.Items.IndexOf(ddlClass.Items.FindByValue(this.defValue));
            ddlClass.DataBind();
        }
        /// <summary>
        /// 创建树结点
        /// </summary>
        private void BindNode(DropDownList ddlNode, int parentid, DataTable dt, string blank)
        {
            DataRow[] drs = dt.Select(""+this.parentId+"= " + parentid);
            foreach (DataRow dr in drs)
            {
                string classid = dr[this.Value].ToString();
                string classname = dr[this.Text].ToString();
                classname = blank + classname;                 ListItem itme = new ListItem();
                itme.Text = classname;
                itme.Value = classid;
                if (itme.Value.Equals(this.defValue))
                    itme.Selected = true;
                ddlNode.Items.Add(itme);                 int sonparentid = int.Parse(classid);
                string blank2 = blank + "─";
                BindNode(ddlNode, sonparentid, dt, blank2);
            }
        }
    }

RadTreeView控件 应用:

<telerik:RadTreeView runat="server" ID="RadTreeView2" Skin="Office2007"
             Width="300px" Height="450px" CheckBoxes="True" DataTextField="ParentID" 
                TriStateCheckBoxes="False">
            </telerik:RadTreeView>  

 AddTree("0", this.RadTreeView2.Nodes);

 public void AddTree(string fdm, RadTreeNodeCollection nodes)
    {
        DataTable dt = DbHelper.ExecuteDataset(SysConst.DBNAME_XIAOWU, "select * from NT_Clcs_Village where ParentID=" + fdm + "").Tables[0];         foreach (DataRow dr in dt.Rows)
        {
            string classid = dr["Cv_ID"].ToString();
            string classname = dr["Cv_Name"].ToString();             RadTreeNode main = new RadTreeNode();
            main.Text = classname;
            main.Value = classid;
            nodes.Add(main);
            AddTree(classid, main.Nodes);
        }
   } 

其它:

dropDownList.SelectedIndex=dropDownList.Items.IndexOf(dropDownList.Items.FindByText(entityBase.Bugstatus));

MVC树形:

使用: @Html.DropDownList("ddlXzqy", ViewData["ddlXzqy"] as IEnumerable<SelectListItem>)

/// <summary>
       /// 创建树
       /// </summary>
       public void BindDrpClass(Guid selectId)
       {
           var list = repo.GetXzqyRootsList();
           List<SelectListItem> selitem = new List<SelectListItem>();
           foreach (var item in list)
           {
               //顶级分类显示形式
               if (selectId == item.ID)
               {
                   selitem.Add(new SelectListItem { Text = "╋" + item.Name, Value = item.ID.ToString(), Selected = true });
                   this.ViewData["selected"] = item.ID.ToString();
               }
               else
               {
                   selitem.Add(new SelectListItem { Text = "╋" + item.Name, Value = item.ID.ToString() });
               }
 
               //递归子分类方法
               string blank = "├";
               BindNode(item.ID, blank, selitem, selectId);
           }
           selitem.Insert(0, new SelectListItem { Text = "==行政区域==", Value = "-1" });
           ViewData["ddlXzqy"] = selitem;
       }
       private void BindNode(Guid parentid, string blank, List<SelectListItem> selitem, Guid selectId)
       {
           var list = repo.GetXzqyChildList(parentid);
           foreach (var item in list)
           {
               if (selectId == item.ID)
               {
                   selitem.Add(new SelectListItem { Text = blank + item.Name, Value = item.ID.ToString(), Selected = true });
                   this.ViewData["selected"] = item.ID.ToString();
               }
               else
               {
                   selitem.Add(new SelectListItem { Text = blank + item.Name, Value = item.ID.ToString() });
               }
               string blank2 = blank + "─";
               BindNode(item.ID, blank2, selitem, selectId);
           }
       }

  RecursionDemo.rar

转载笔记:DropDownList无限级分类(灵活控制显示形式)的更多相关文章

  1. C#无限级分类递归显示示例

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="RoleDemo20150305 ...

  2. 2强类型DataSet (2011-12-30 23:16:59)转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 http://blog.sina.com.cn/s/blog_9d90c4140101214w.html

    强类型DataSet (2011-12-30 23:16:59) 转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 using System; using System.Collections.G ...

  3. 强类型DataSet (2011-12-30 23:16:59)转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 http://blog.sina.com.cn/s/blog_9d90c4140101214w.html

    强类型DataSet (2011-12-30 23:16:59) 转载▼ 标签: 杂谈 分类: Asp.Net练习笔记 using System; using System.Collections.G ...

  4. MVC无限级分类02,增删改查

    继上一篇"MVC无限级分类01,分层架构,引入缓存,完成领域模型与视图模型的映射",本篇开始MVC无限级分类的增删改查部分,源码在github. 显示和查询 使用datagrid显 ...

  5. PHP递归实现无限级分类

    在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...

  6. mysql无限级分类

    第一种方案: 使用递归算法,也是使用频率最多的,大部分开源程序也是这么处理,不过一般都只用到四级分类. 这种算法的数据库结构设计最为简单.category表中一个字段id,一个字段fid(父id).这 ...

  7. (实用篇)PHP递归实现无限级分类

    在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...

  8. PHP无限级分类-递归(不推荐)

    [http://www.helloweba.com/view-blog-204.html] 在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢? ...

  9. STM32学习笔记(四)——串口控制LED(中断方式)

    目录: 一.时钟使能,包括GPIO的时钟和串口的时钟使能 二.设置引脚复用映射 三.GPIO的初始化配置,注意要设置为复用模式 四.串口参数初始化配置 五.中断分组和中断优先级配置 六.设置串口中断类 ...

随机推荐

  1. 纯swift开发,弹幕,演唱会广告牌

    最近去了次演唱会,看见有人在用这个,刚好没事,我自己也写了一个. 顺手练一练swift,第一个纯swift开发工程. 支持字体大小切换,滚动速度切换,字体切换,字体颜色切换 工程Git:https:/ ...

  2. Vector/Push_back

    https://bbs.csdn.net/topics/370225285 https://blog.csdn.net/u013630349/article/details/46853297 http ...

  3. Ajax中异步与同步的区别

    同步可以解决,只有前一个请求结束后,当前请求才会发起.

  4. Kettle-6.1安装部署及使用教程

    一.Kettle概念 Kettle是一款国外开源的ETL工具,纯java编写,可以在Window.Linux.Unix上运行,绿色无需安装,数据抽取高效稳定. Kettle 中文名称叫水壶,该项目的主 ...

  5. 手动安装R包

    1,先将R包下载到本地 2,getwd() setwd("F:\\CNV\\Paper\\Case-control\\mHMM") 3, install.packages(&quo ...

  6. leetcode记录-字符串转整数

    实现 atoi,将字符串转为整数. 该函数首先根据需要丢弃任意多的空格字符,直到找到第一个非空格字符为止.如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连续的数字组合起来,这部分字 ...

  7. 鼠标移动在屏幕上显示温度Tip提示功能-CToolTipCtrl类的使用

    初学VC++,太多知识不懂,需要不断的查找资料,想通过记录让自己有所积累,主要是怕以后会很快忘记.最近在做一个在屏幕上显示鼠标移动位置的温度值,我利用先缓存一帧图像的温度值,然后,通过鼠标移动消息相应 ...

  8. Linux入门进阶第一天——vim文本编辑器

    一.VI / VIM概述 [更新]:VIM资料参见:http://www.runoob.com/linux/linux-vim.html 是什么? 是一个文本编辑器. Vim是从 vi 发展出来的一个 ...

  9. 20155320 2016-2017-2 《Java程序设计》第二周学习总结

    20155320 2016-2017-2 <Java程序设计>第二周学习总结 教材学习内容总结 本周主要学习了java语言的基础语法,我发现与以前学过的c语言有许多共同点,无论是从一些基本 ...

  10. [SDOI2010]地精部落 DP

    LG传送门 DP好题 题意很简单,就是求1-n的排列,满足一个数两边的数要么都比它大要么都比它小,求这样的排列个数对\(p\)取膜的值(为了表述简单,我们称这样的排列为波动序列). 这个题我第一眼看到 ...