欢迎来到代码驿站!

.NET代码

当前位置:首页 > 软件编程 > .NET代码

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

时间:2021-04-25 10:09:58|栏目:.NET代码|点击:
在网上找了很久也没有找到例子,没办法了,想偷懒也偷不成了,还是自己老老实实的写一个吧。不多废话,下面请看我做的详细方法。

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

上一篇:ASP.NET笔记之 Httphandler的操作详解

栏    目:.NET代码

下一篇:c#后台线程访问前台控件并显示信息示例

本文标题:Asp.net 无限级分类实例代码

本文地址:http://www.codeinn.net/misctech/108226.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有