a.aspx<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" >
<head id="Head1" runat="server">
    <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title></title>
    <link href="Untitled-1.css" rel="stylesheet" type="text/css" />
</head>
<script language="javascript" type="text/javascript">
      <!--
       // ACLOUD 常用JS函数
       function getBid(s){
  return document.getElementById(s);
}
function getBmc(s){
  return document.getElementByName(s);
}

       //显示分类列表
   function showNext(sid,obj)
        { 
          if(sid==null || sid=="" || sid.length<1)return;
          var slt =getBid(obj);
      var v = _Default.getNextClass(sid).value; // 类的名称
      //alert(v);
      //return;
      if (v != null){      
  if(v != null && typeof(v) == "object" && v.Tables != null)
{
    slt.length = 0;
    slt.options.add;
    //加了个“请选择”主要为了触发onchange事件
    if(obj=="ddl2"){
    }
for(var i=0; i<v.Tables[0].Rows.length; i++)
     {
     var txt = v.Tables[0].Rows[i].txt; //这个地方需要注意区分大小写
       var vol = v.Tables[0].Rows[i].vol; //跟dataset表的列名称要一致
       slt.options.add(new Option(txt,vol));
     }
}
   }
   return;
        }
        -->
</script>
<body>
    <form id="form1" runat="server">
    <div class="table1">
    <li>a</li>
    <li>b</li>
    <li>c</li>
    <li>d</li>
    <li>e</li></div><br />
    <div class="table1">
        <li><asp:DropDownList ID="ddl1" runat="server" Width="70px">
        </asp:DropDownList></li>
        <li><asp:DropDownList ID="ddl2" runat="server" Width="70px">
        </asp:DropDownList></li>
        <li><asp:TextBox ID="TextBox1" runat="server" MaxLength="15" Width="90px"></asp:TextBox></li>
        <li><asp:TextBox ID="TextBox2" runat="server" Width="80px"></asp:TextBox></li>
        <li><asp:TextBox ID="TextBox3" runat="server" MaxLength="11" Width="80px"></asp:TextBox></li>
        <li><asp:Button ID="Button1" runat="server" Text="提交" /></li></div>
    </form>
</body>
</html>a.aspx.csusing System;
using System.Data;
using System.Configuration;
using System.Data.OleDb;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;public partial class _Default : System.Web.UI.Page
{
    protected void Page_Load(object sender, EventArgs e)
    {
        AjaxPro.Utility.RegisterTypeForAjax(typeof(_Default)); //必要的
        if (!IsPostBack) BindDc();
    }    /// <summary>
    /// 数据库连接
    /// </summary>
    /// <returns></returns>
    public OleDbConnection myConn()
    {
        string ConnStr = "Provider=Microsoft.Jet.OLEDB.4.0;Data Source=" + System.Web.HttpContext.Current.Server.MapPath(ConfigurationManager.AppSettings["dbpath"]);
        OleDbConnection conn = new OleDbConnection(ConnStr);
        try
        {
            conn.Open();
            return conn;
        }
        catch
        {
            throw;
        }
    }    /// <summary>
    /// 获取下级分类
    /// </summary>
    [AjaxPro.AjaxMethod]
    public DataSet getNextClass(string cid)
    {
        //因为不希望页面可以知道字段名称 所以 as txt,id as vol 如果是sql ser 可以用 = 
        //页面获取的 列名称 必须跟这个一同样 而且区分大小写 一般都是这个地方容易疏忽了
        //所以二级分类没变化
        string sql = @"select cname as txt,id as vol from webclass where parentid=" + cid;
        try
        {
            return getDs(sql);
        }
        catch
        {
            //throw;
            return null;
        }
    }
    /// <summary>
    /// 返回一个DataSet
    /// </summary>
    /// <param name="SQL"></param>
    /// <returns></returns>
    public DataSet getDs(string SQL)
    {
        OleDbConnection conn = myConn();
        DataSet Ds = new DataSet();
        OleDbDataAdapter Da = new OleDbDataAdapter(SQL, conn);
        try
        {
            Da.Fill(Ds);
            return Ds;
        }
        catch
        {
            return null;
            //throw;
        }    }
    /// <summary>
    /// //数据绑定
    /// </summary>
    private void BindDc()
    {
        //第一个
        string sql = @"select * from webclass where Parentid=0";
        ddl1.DataSource = getDs(sql);
        ddl1.DataTextField = "cname";
        ddl1.DataValueField = "id";
        ddl1.DataBind();
        if (ddl1.DataSource != null) ddl1.Attributes.Add("onchange", "showNext(this.options[selectedIndex].value,'ddl2');");
        //可以先判断 DropDownList.SelectedItem.Value
        //第二个
        sql = @"select * from webclass where parentid=" + ddl1.SelectedItem.Value;
        ddl2.DataSource = getDs(sql);
        ddl2.DataTextField = "cname";
        ddl2.DataValueField = "id";
        ddl2.DataBind();    }
}

解决方案 »

  1.   


    <asp:Button ID="Button1" runat="server" Text="提交" OnClick="Button1_Click" />protected void Button1_Click(object sender,EventArgs e)
    {
      //code;
    }
      

  2.   

    jsvar sendvalue = function(){
        _Default.Send_Value(value,is_backcall);
    }
    var is_backcall = function(res){
        var _alert = res.value;
        if(_alert == "0")
           alert('失败');
         else
            alert('成功');
    }cs
    ///  <summary> 
    /// 获取下级分类 
    ///  </summary> 
    [AjaxPro.AjaxMethod()] 
    public void Send_Value(string T_Value)
    {
         //提交数据库操作,这里自己写好了
          if(成功条件)
            return "1";//成功
          else
            return "0";//失败
    }
      

  3.   

    jsvar sendvalue = function(){
        _Default.Send_Value(value,is_backcall);
    }
    var is_backcall = function(res){
        var _alert = res.value;
        if(_alert == "0")
           alert('失败');
         else
            alert('成功');
    }cs
    ///  <summary> 
    /// 获取下级分类 
    ///  </summary> 
    [AjaxPro.AjaxMethod()] 
    public void Send_Value(string T_Value)
    {
         //提交数据库操作,这里自己写好了
          if(成功条件)
            return "1";//成功
          else
            return "0";//失败
    }
      

  4.   

    <asp:Button ID="Button1" runat="server" onclick="sendvalue()" Text="提交" />忘记了,在JS sendvalue函数里 要获取值后传递_Default.Send_Value(value,is_backcall);value就是传递的值  可以多个_Default.Send_Value(value1,value2......,is_backcall);根据需要 后台Send_Value方法的参数要一一对应
      

  5.   

    楼主使用了ajaxpro框架做的事情就该是ajax异步提交操作
      

  6.   

    <asp:Button ID="Button1" runat="server" onclick="sendvalue()" Text="提交" /> 忘记了,在JS sendvalue函数里 要获取值后传递 _Default.Send_Value(value,is_backcall); value就是传递的值  可以多个 _Default.Send_Value(value1,value2......,is_backcall); 根据需要 后台Send_Value方法的参数要一一对应