无限级下拉列表的无限级分级[asp.net](转)

None.gif 1 . 无限级分类肯定要数据库支持啦,用户可以动态添加他们的分类嘛,下面是数据库的结构: 
None.gif
None.gif
None.gif
None.gif
None.gif 
None.gif
None.gif    数据库主要有三个字段,这是最基本的了。第一个是主键,第二个是分类的名称了,第三个是父级目录id号。
None.gif
None.gif     
None.gif
None.gif       
2 。成品的效果图:(大家最关心的是不是这个啊?看看是什么样子再看程序怎么吧) 看!!就长这个模样啦,这个层次关系就是上面那个数据所显示的结果。怎么样?还行吧。。。
None.gif
None.gif 
None.gif
None.gif
None.gif       
3 。最后就是提供程序咯,程序其实就是一个递归算法。
None.gif
None.gif
None.gif 
private   void  GetArticleCategory( string  pid)
None.gif
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif
InBlock.gif        SqlConnection conn 
= new SqlConnection("server=.;database=test;uid=sa;pwd=;");
InBlock.gif
InBlock.gif        
string sql = "select Articlesgroup_id,Groupname from Articlesgroup where Articlesgroup_parent_id=@pid order by Groupname";
InBlock.gif
InBlock.gif        SqlCommand cmd 
= new SqlCommand(sql, conn);
InBlock.gif
InBlock.gif        SqlParameter Pid 
= new SqlParameter("@pid", SqlDbType.Int);
InBlock.gif
InBlock.gif        Pid.Value 
= pid;
InBlock.gif
InBlock.gif        cmd.Parameters.Add(Pid);
InBlock.gif
InBlock.gif        conn.Open();
InBlock.gif
InBlock.gif        SqlDataReader sdr 
= cmd.ExecuteReader();
InBlock.gif
InBlock.gif        
while (sdr.Read())
InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif
InBlock.gif
InBlock.gif            
this.DropDownList1.Items.Add(new ListItem(toadd + " " + sdr[1].ToString(), sdr[0].ToString()));
InBlock.gif
InBlock.gif            toadd 
+= "─┴";
InBlock.gif
InBlock.gif            
this.GetArticleCategory(sdr[0].ToString());
InBlock.gif
InBlock.gif           toadd 
= toadd.Substring(0, toadd.Length - 2);  //开始这里没有处理好,层次关系显示不出来  :)
InBlock.gif

ExpandedSubBlockEnd.gif        }

InBlock.gif
InBlock.gif        sdr.Close();
InBlock.gif
InBlock.gif        conn.Close();
InBlock.gif
ExpandedBlockEnd.gif    }

None.gif
None.gif
None.gif调用方法:在Page_Load里调用
None.gif
None.gif
None.gif  
protected   void  Page_Load( object  sender, EventArgs e)
None.gif
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif
InBlock.gif        
this.keyword.Attributes.Add("onfocus","if( this.value=='key key key') {this.value='' };");
InBlock.gif
InBlock.gif        
if (!Page.IsPostBack)
InBlock.gif
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif
InBlock.gif            
this.GetArticleCategory("0");
InBlock.gif
ExpandedSubBlockEnd.gif        }

InBlock.gif
InBlock.gif        
this.DropDownList1.Items.Insert(0new ListItem("Search All""all"));
InBlock.gif
ExpandedBlockEnd.gif    }

None.gif
None.gif
None.gif
None.gif
None.gif  在类里边还要定义一个变量
None.gif
None.gif
private   string  toadd  =   " " ;
None.gif
None.gif     到这里所有东西都搞定啦,就这么简单。。。。。
None.gif

转载于:https://www.cnblogs.com/gjahead/archive/2007/04/10/707011.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值