广

ASP.NET

  • IOS开发
  • android开发
  • PHP编程
  • JavaScript
  • ASP.NET
  • ASP编程
  • JSP编程
  • Java编程
  • 易语言
  • Ruby编程
  • Perl编程
  • AJAX
  • 正则表达式
  • C语言
  • 编程开发

    Asp.net 无限级分类实例代码

    2018-05-07 10:24:33 次阅读 稿源:互联网
    广告
    在网上找了很久也没有找到例子,没办法了,想偷懒也偷不成了,还是自己老老实实的写一个吧。不多废话,下面请看我做的详细方法。

    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 = "├"; 

    一起学吧部分文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与一起学吧进行文章共享合作。

    广告
    广告
    广告