asp.net DropDownList 三级联动下拉菜单实现代码

 更新时间:2009年12月05日 23:29:19   作者:  
asp.net DropDownList 三级联动下拉菜单效果代码,需要的朋友可以参考下。
复制代码 代码如下:

if (!IsPostBack)
{
//一级分类列表
this.DropDownList1.DataSource = dsbb.SelectSubjct1();
this.DropDownList1.DataTextField = "cName";
this.DropDownList1.DataValueField = "Ccode";
this.DropDownList1.DataBind();
this.DropDownList1.Items.Insert(0,new ListItem("请选择一级分类","0"));
this.DropDownList8.Items.Insert(0, new ListItem("请选择二级分类", "0"));
this.DropDownList9.Items.Insert(0,new ListItem ("请选择三级分类","0"));
//二级分类列表

}
/// <summary>
/// 绑定二级分类
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
libs.Database.Dbbase dbb = new libs.Database.Dbbase();
if (Convert.ToInt32(this.DropDownList1.SelectedValue) == 0) //清除列表内容
{
this.DropDownList8.Items.Clear();
this.DropDownList8.Items.Insert(0, new ListItem("请选择二级分类", "0"));
this.DropDownList9.Items.Clear();
this.DropDownList9.Items.Insert(0, new ListItem("请选择三级分类", "0"));
}
else //二级分类列表
{
this.DropDownList8.DataSource = dbb.Selectsubjct2(this.DropDownList1.SelectedValue.Substring(0,2));
this.DropDownList8.DataTextField = "cName";
this.DropDownList8.DataValueField = "Ccode";
this.DropDownList8.DataBind();
this.DropDownList8.Items.Insert(0,new ListItem ("请选择二级分类","0"));
this.DropDownList9.Items.Clear();//清除第三分类
this.DropDownList9.Items.Insert(0, new ListItem("请选择三级分类", "0"));
}
}
/// <summary>
/// 绑定三级分类
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
protected void DropDownList8_SelectedIndexChanged(object sender, EventArgs e)
{
libs.Database.Dbbase dbase = new libs.Database.Dbbase();
this.DropDownList9.DataSource = dbase.selectsubject3(this.DropDownList8.SelectedValue.Substring(0,4));
this.DropDownList9.DataTextField = "cName";
this.DropDownList9.DataValueField = "Ccode";
this.DropDownList9.DataBind();
this.DropDownList9.Items.Insert(0,new ListItem("请选择三级分类","0"));
}


Dbbase.cs页:
复制代码 代码如下:

/// <summary>
/// 查询一级栏目
/// </summary>
/// <returns></returns>
public DataSet SelectSubjct1()
{
string con = System.Configuration.ConfigurationSettings.AppSettings["sqlconn"];
SqlConnection conn = new SqlConnection(con);
string sqlstr = "SELECT kndid, Ccode, cName, cLevel FROM kind WHERE cLevel = 1";
DataSet dst = new DataSet();
SqlDataAdapter sda = new SqlDataAdapter(sqlstr,conn);
try
{
sda.Fill(dst);
return dst;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
conn.Close();
}
}
/// <summary>
/// 查询二级栏目内容
/// </summary>
/// <param name="ccode"></param>
/// <returns></returns>
public DataSet Selectsubjct2(string ccode)
{
string conn1 = System.Configuration.ConfigurationSettings.AppSettings["sqlconn"];
SqlConnection conn = new SqlConnection(conn1);
string sqqq = "select kndid,Ccode,cName,cLevel from kind where cLevel = 2 and Ccode like '" + ccode + "%'";
DataSet dss = new DataSet();
SqlDataAdapter sdd = new SqlDataAdapter(sqqq,conn);
try
{
sdd.Fill(dss);
return dss;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
conn.Close();
}
}
/// <summary>
/// 查询三级栏目内容
/// </summary>
/// <param name="cde"></param>
/// <returns></returns>
public DataSet selectsubject3(string cde)
{
string conn2 = System.Configuration.ConfigurationSettings.AppSettings["sqlconn"];
SqlConnection conn = new SqlConnection(conn2);
string sqq = "select kndid,Ccode,cName,cLevel from kind where cLevel = 3 and Ccode like '" + cde + "%'";
DataSet dst = new DataSet();
SqlDataAdapter sdaa = new SqlDataAdapter(sqq,conn);
try
{
sdaa.Fill(dst);
return dst;
}
catch (Exception ex)
{
throw new Exception(ex.Message);
}
finally
{
conn.Close();
}
}

注意:DropDownList1_SelectedIndexChanged 事件,AutoPostBack="True"

相关文章

  • ASP.NET MVC5网站开发之用户资料的修改和删除3(七)

    ASP.NET MVC5网站开发之用户资料的修改和删除3(七)

    这篇文章主要为大家详细介绍了ASP.NET MVC5网站开发之用户资料的修改和删除,感兴趣的小伙伴们可以参考一下
    2016-08-08
  • .NET Core下使用Log4Net记录日志的方法步骤

    .NET Core下使用Log4Net记录日志的方法步骤

    这篇文章主要介绍了.NET Core下使用Log4Net记录日志的方法步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-09-09
  • .net微信服务号发送红包

    .net微信服务号发送红包

    这篇文章主要为大家详细介绍了.net微信服务号发送红包的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • Asp.net回调技术Callback学习笔记

    Asp.net回调技术Callback学习笔记

    这篇文章主要记录了Asp.net回调技术Callback的一些知识,感兴趣的朋友可以参考下
    2014-08-08
  • 随机图片生成器制作方法分享

    随机图片生成器制作方法分享

    .net处理程序生成随机6位图片验证码,大家参考使用吧
    2013-12-12
  • .NET9 AOT部署方案详解

    .NET9 AOT部署方案详解

    文章详细介绍了.NET AOT(Ahead-of-Time)和JIT(Just-in-Time)两种编译和部署方式的对比,包括它们的优点和缺点,AOT适合快速启动、内存占用低、性能稳定的场景,这篇文章主要介绍了.NET9 AOT部署,需要的朋友可以参考下
    2025-01-01
  • ASP.NET中Dictionary基本用法实例分析

    ASP.NET中Dictionary基本用法实例分析

    这篇文章主要介绍了ASP.NET中Dictionary基本用法,结合实例形式分析了Dictionary的基本功能、使用步骤与相关操作技巧,需要的朋友可以参考下
    2016-08-08
  • ASP.NET中实现文件的保护性下载基础篇

    ASP.NET中实现文件的保护性下载基础篇

    许多时候,我们需要在因特网上提供文件下载服务,但是又要防止未经授权的下载,这时该怎么办?本文将为读者详细介绍一种使用ASP.NET实现的HTTP处理程序的解决方案。
    2011-02-02
  • 使用Lable控件输出九九乘法表

    使用Lable控件输出九九乘法表

    这篇文章主要为大家详细介绍了使用Lable控件输出九九乘法表,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • Asp.net控制Tomcat启动关闭的实现方法

    Asp.net控制Tomcat启动关闭的实现方法

    近日有个项目客户要求能自己配置相关权限。由于历史原因这个项目采用的是公司以前的权限系统
    2012-01-01

最新评论