• 【转载】Asp.net DropDownList 无限级分级


    http://hi.baidu.com/kb81/blog/item/c8315f8236e85aa20cf4d201.html

     近期做的一个网站需要一个无限级下拉列表的无限级分级功能,于是就有了下面的小作品。
           开始以为无限级下拉列表功能应该很简单,无非就是用一个递归算法就好啦,但是在做起来的时候却会遇到一些比较模糊的东西。在网上找了很久也没有找到例子,没办法了,想偷懒也偷不成了,还是自己老老实实的写一个吧。不多废话,下面请看我做的详细方法。

           1。无限级分类肯定要数据库支持啦,用户可以动态添加他们的分类嘛,下面是数据库的结构:

    数据库主要有三个字段,这是最基本的了。第一个是主键,第二个是分类的名称了,第三个是父级目录id号。
        
           2。成品的效果图:(大家最关心的是不是这个啊?看看是什么样子再看程序怎么吧)
    看!!就长这个模样啦,这个层次关系就是上面那个数据所显示的结果。怎么样?还行吧。。。

           3。最后就是提供程序咯,程序其实就是一个递归算法。
        private void GetArticleCategory(string pid)
        {
            SqlConnection conn = new SqlConnection("server=.;database=test;uid=sa;pwd=;");
            string sql = "select Articlesgroup_id,Groupname from Articlesgroup where Articlesgroup_parent_id=@pid order by Groupname";
            SqlCommand cmd = new SqlCommand(sql, conn);
            SqlParameter Pid = new SqlParameter("@pid", SqlDbType.Int);
            Pid.Value = pid;
            cmd.Parameters.Add(Pid);
            conn.Open();
            SqlDataReader sdr = cmd.ExecuteReader();
            while (sdr.Read())
            {
                this.DropDownList1.Items.Add(new ListItem(toadd + " " + sdr[1].ToString(), sdr[0].ToString()));
                toadd += "─┴";
                this.GetArticleCategory(sdr[0].ToString());
                toadd = toadd.Substring(0, toadd.Length - 2);  //开始这里没有处理好,层次关系显示不出来  :)
            }
            sdr.Close();
            conn.Close();
        }

    调用方法:在Page_Load里调用
        protected void Page_Load(object sender, EventArgs e)
        {
            this.keyword.Attributes.Add("onfocus","if( this.value=='key key key') {this.value='' };");
            if (!Page.IsPostBack)
            {
                this.GetArticleCategory("0");
            }
            this.DropDownList1.Items.Insert(0, new ListItem("Search All", "all"));
        }

    在类里边还要定义一个变量
    private string toadd = "├";

           到这里所有东西都搞定啦,就这么简单。。。。。

  • 相关阅读:
    2018爆零记第二弹之day0
    2018NOIP爆0记第一弹
    图论中偶然发现的一个问题
    [SCOI2010]序列操作
    CF 675E Trains and Statistic
    CF100015C
    Python 使用 NLTK 实现简单情感分析--Twitter(推特)分析
    pipenv -- python 搭建虚拟环境
    Python
    ElasticSearch 入门教程
  • 原文地址:https://www.cnblogs.com/blsong/p/1631869.html
Copyright © 2020-2023  润新知