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

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 无限级分类相关推荐

  1. ASP.NET 无限级分类实现实例(深度字段)

    下图中红色箭头是父类 而且属于根目录级别. 下面个字段为:ID 父ID 类型名称 深度 排序 前面3个字段没有什么可解释的,做过无限级分类设计的人都应该清楚 而第5个字段排序字段ID:43的23排序代 ...

  2. ASP无限级分类代码

    数据库结构 表:分类 效果图 代码 <%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%> <% Option Exp ...

  3. .net简单算法实现无限级分类(一)

    在项目中我们往往需要实现无限级分类,而网上的.NET的例子不是很多,asp的倒是不少,这个算法是我根据网上的asp的例子在结合.net中的TREEVIEW控件来实现多级甚至无限级分类.      对于 ...

  4. 存储过程实现无限级分类(3)

    存储过程实现无限级分类(3) 最后一步显示分类(只是一条select语句) CREATE PROCEDURE sp_Column_List   AS SELECT Column_ID, Column_ ...

  5. php数组无限文类,php把无限级分类生成数组的类

    你是否遇到需要把无限级分类循环出来,是不是很头痛. 比如,要循环出一个SELECT,或一个TABLE,要写一大堆判断. 我的做法是生成数组,可以重复调用,直接循环数组就行了.为了方便,把它写成了类:c ...

  6. jquery实现层级显示 效果图_php运用无限级分类实现评论及回复功能

    经常在各大论坛或新闻板块详情页面下边看到评论功能,当然不单单是直接发表评论内容那么简单,可以对别人的评论进行回复,别人又可以对你的回复再次评论或回复,如此反复,理论上可以说是没有休止; 从技术角度分析 ...

  7. 无限级分类实现思路 (组织树的分级管理)

    2019独角兽企业重金招聘Python工程师标准>>> 关于该问题,暂时自己还没有深入研究,在网上找到几种解决方案,各有优缺点. 第一种方案: 使用递归算法,也是使用频率最多的,大部 ...

  8. php修改新闻分类代码,完整的新闻无限级分类代码,可添加,删除,移动,修改

    //连接数据库教程 $link = mysql教程_connect('localhost','root','密码') or die(mysql_error()); mysql_select_db('s ...

  9. 迭代与递归实现无限级分类

    无限级分类是开发中常见的情况了,在这里我收藏了下并整理了下常见的无限极分类算法总结归纳. <?php $arr = [1=>['id'=>1,'name'=>'家居','fat ...

  10. php无限分类原理,php 递归无限级分类原理和实现代码

    递归无限级分类的原理: 每一个分类都记录它的父级id,当为顶级分类时,父级id为0.这样无论哪个分类,都可以通过父级id一层一层去查明它的所有父级,以便清楚知道它所属何种分类,层级深度为几. 对数据进 ...

最新文章

  1. iOS WebviewJavascriptBridge 源码研读笔记
  2. 脉讯发布“社群搜索工具” 助企业精准洞察消费者需求
  3. [c]如何通过结构体元素找到结构体?
  4. java中String的比较符
  5. ASP.NET中过滤HTML字符串的两个方法
  6. 调用布尔变量java_关于java的参数的调用,还有布尔的理解,这有一段代码,我有些不太理解,希望能够帮我分析下,谢谢...
  7. html字体变大自动换行,网页css中实现字符超出宽度自动换行和英语字符不断行的解决方法...
  8. HDU6395 Sequence(矩阵快速幂+数论分块)
  9. LRU的两种实现方案
  10. 测试是浪费时间,我的程序肯定没问题
  11. 手机语音翻译的小妙招,一步一步教你!一键音频转文字
  12. Java操作Mysql实例
  13. 内联函数与宏定义的区别
  14. 电脑硬件名称 中英文对照
  15. 推荐一款.NET开源免费的图表控件ScottPlot
  16. C语言实现埃拉托斯特尼筛法
  17. 利用极域电子教室控制别人电脑
  18. html中写jq,在jQuery中,能够操作HTML代码及其文本的方法是()
  19. 万字拆解增长的算法:从产品、流量、品牌到文化
  20. java dataframe agg_Pandas对DataFrame单列/多列进行运算(map, apply, transform, agg)

热门文章

  1. 一文弄懂nginx反向代理和负载均衡
  2. 风口上的“低代码”,是时候来系统学一学了
  3. 盛大“传奇”的网游启示录
  4. 全面规范的软件需求可以规避项目风险
  5. 读ZAC网络营销实战密码有感
  6. 3.6 Spark安装与体验
  7. 5.12 CopyNet和 Pointer-Generator Net 复制机制和指针-生成器网络
  8. 3分钟tips:什么是特征向量?什么是特征值?
  9. Java:接口interface
  10. Scala:函数式编程之下划线underscore