Ajax的DropDrowList应用——改变一个drp会引起另一个drp的值改变

通过Ajax技术对DropDrowList控件联动改变应用

改变一个DropDrowList会引起另一个DropDrowList的值改变:

Page Code:

<table>
            <tr>
                <th>省份</th>
                <td>
                    <asp:DropDownList ID="drpProvice" runat="server" 
                        onselectedindexchanged="drpProvice_SelectedIndexChanged" AutoPostBack="True">
                    </asp:DropDownList>
                </td>
                <th>城市</th>
                <td><asp:DropDownList ID="drpCity" runat="server">
                    </asp:DropDownList></td>
            </tr>
        </table>

Class Code:

protected void Page_Load(object sender, EventArgs e)
        {
			if (!IsPostBack)
			{
				InitData();
			}
        }
		
		protected virtual Int32 StringToInt32(string val, Int32 defaultVal)
		{
			int tmp = 0;
			if (Int32.TryParse(val, out tmp))
			{
				return tmp;
			}
			return defaultVal;
		}
		public SqlConnection Open()
		{
			string strConn = ConfigurationManager.ConnectionStrings["MySqlDataBase"].ConnectionString;
			SqlConnection conn = new SqlConnection(strConn);
			conn.Open();
			return conn;
		}
		public void Close()
		{
			SqlConnection conn = Open();
			conn.Close();
		}
		private void InitData()
		{
			ProviceBind();
			Citybind();
		}
		private void ProviceBind()
		{
			string strSql = "select * from Ajax_Provice";
			SqlConnection conn = Open();
			SqlDataAdapter da = new SqlDataAdapter(strSql, conn);
			DataSet ds = new DataSet();
			da.Fill(ds);
			drpProvice.DataSource = ds.Tables[0];
			drpProvice.DataTextField = "c_provName";
			drpProvice.DataValueField = "c_provId";
			drpProvice.DataBind();
			//drpTypeId.Items.Insert(0, new ListItem("全部", ""));

		}
		private void Citybind()
		{
			int temp = StringToInt32(drpProvice.SelectedValue, 0);
			string strSql = "select * from Ajax_City Where c_provId = {0}";
			strSql = string.Format(strSql, temp);
			SqlConnection conn = Open();
			SqlDataAdapter da = new SqlDataAdapter(strSql, conn);
			DataSet ds = new DataSet();
			da.Fill(ds);
			drpCity.DataSource = ds.Tables[0];
			drpCity.DataTextField = "c_city";
			drpCity.DataValueField = "c_provId";
			drpCity.DataBind();
			Close();
		}
		protected void drpProvice_SelectedIndexChanged(object sender, EventArgs e)
		{
			Citybind();
		}
当然只有这些代码,是不行的,要记住一点要把DropDrowList的属性 AutoPostBack设置为"True",不然不会有联动的效果哦。
数据库图:



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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

fengzhilu000

送人玫瑰,手留余香!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值