zoukankan      html  css  js  c++  java
  • 笔记:DropDownList无限级分类(灵活控制显示形式)

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


    最终样式:


     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    }

    数据访问(Bll里面的classSystem方法 )


    源码下载:
    https://files.cnblogs.com/chensubo/RecursionDemo.rar
  • 相关阅读:
    Xshell添加快捷按钮
    Go语言基础之21--反射
    Jenkins自动化CI CD流水线之7--流水线自动化发布PHP项目
    Jenkins自动化CI CD流水线之6--构建邮件状态通知
    Jenkins自动化CI CD流水线之5--pipeline
    Python练习-函数(方法)的定义和应用
    Python文件操作-文件的增删改查
    Python练习-不知道弄个什么鬼
    Python练习-短小精干版三级"片儿"
    Python练习-三级菜单与"片儿"无关!
  • 原文地址:https://www.cnblogs.com/chensubo/p/1067037.html
Copyright © 2011-2022 走看看