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

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

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

相关文章

  • ADO.NET实用经验汇总

    ADO.NET实用经验汇总

    这篇文章主要介绍了ADO.NET实用经验汇总,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • Asp.net下用JQuery找出哪一个元素引起PostBack

    Asp.net下用JQuery找出哪一个元素引起PostBack

    在Asp.net webform中,如何找出哪一个按钮触发Button PostBack事件。
    2010-06-06
  • ASP.NET MVC实现区域路由

    ASP.NET MVC实现区域路由

    这篇文章介绍了ASP.NET MVC实现区域路由的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • mvc file控件无刷新异步上传操作源码

    mvc file控件无刷新异步上传操作源码

    这篇文章主要为大家分享了mvc file控件无刷新异步上传操作源码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • ASP.Net MVC_DotNetZip简单使用方法,解决文件压缩的问题

    ASP.Net MVC_DotNetZip简单使用方法,解决文件压缩的问题

    下面小编就为大家带来一篇ASP.Net MVC_DotNetZip简单使用方法,解决文件压缩的问题。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • 在Asp.net core中实现websocket通信

    在Asp.net core中实现websocket通信

    这篇文章介绍了在Asp.net core中实现websocket通信的方法,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-07-07
  • Asp.net中的数据绑定Eval和Bind应用示例

    Asp.net中的数据绑定Eval和Bind应用示例

    这篇文章主要介绍了Asp.net中的数据绑定Eval和Bind的应用,需要的朋友可以参考下
    2014-05-05
  • .net 4.5部署到docker容器的完整步骤

    .net 4.5部署到docker容器的完整步骤

    这篇文章主要给大家介绍了关于.net 4.5部署到docker容器的完整步骤,文中通过示例代码介绍的非常详细,对大家学习或者使用.net4.5具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-04-04
  • 实例说明asp.net中的简单角色权限控制

    实例说明asp.net中的简单角色权限控制

    权限控制在信息管理中属于基本功能,权限控制中其中以Window权限为模型的角色用户(也称用户组用户)模型使用较多。本文以网站管理后台权限控制为例简要说明。
    2009-10-10
  • Request.RawUrl 属性的应用收

    Request.RawUrl 属性的应用收

    用来对字符串分析,有选择的导向。
    2009-06-06

最新评论