源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-09-29 21:30 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Asp.net 无限级分类实例代码
在网上找了很久也没有找到例子,没办法了,想偷懒也偷不成了,还是自己老老实实的写一个吧。不多废话,下面请看我做的详细方法。 1。无限级分类肯定要数据库支持啦,用户可以动态添加他们的分类嘛,下面是数据库的结构: [img]http://files.jb51.net/upload/20080703091019375.jpg[/img] 数据库主要有三个字段,这是最基本的了。第一个是主键,第二个是分类的名称了,第三个是父级目录id号。 2。成品的效果图:(大家最关心的是不是这个啊?看看是什么样子再看程序怎么吧) [img]http://files.jb51.net/upload/20080703091019693.jpg[/img] 看!!就长这个模样啦,这个层次关系就是上面那个数据所显示的结果。怎么样?还行吧。。。 3。最后就是提供程序咯,程序其实就是一个递归算法。
[u]复制代码[/u] 代码如下:
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里调用 
[u]复制代码[/u] 代码如下:
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"));  } 
在类里边还要定义一个变量 
[u]复制代码[/u] 代码如下:
private string toadd = "├"; 
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部