ASP.NET——实现两个下拉框动态联动

引入:

      在网页中,我们经常会遇到下图中的情况。首先在下拉框中选择所在的省,选择之后,第二个下拉框会自动加载出该省中的市。这样设计极大的方便了用户的查找。那这是如何实现的呢?



1、建立数据库

“省”表


“市”表



2、添加控件


3、两个下拉框分别绑定数据源

      protected void Page_Load(object sender, EventArgs e)
        {
            //判断是否第一次进入页面,如果是,则绑定数据库;如果不是,则无需绑定。
            if (!this.IsPostBack)
            {
                //绑定省   

                SqlConnection con = DB.createConnection();
                con.Open();
                string cmdText = "select* from province";
                SqlCommand cmd = new SqlCommand(cmdText, con);
                SqlDataReader sdr = cmd.ExecuteReader();
                this.DropDownList1.DataSource = sdr;
                this.DropDownList1.DataTextField = "proName";//文本内容
                this.DropDownList1.DataValueField = "proID"; //数据源字段
                this.DropDownList1.DataBind();
                sdr.Close();

                //绑定市
                string cmdCityText = "select* from city where proID=" + this.DropDownList1.SelectedValue;
                SqlCommand cmdCity = new SqlCommand(cmdCityText, con);
                sdr = cmdCity.ExecuteReader();
                //剩下部分与绑定省类似,略
               
                //关闭连接
                con.Close();
            }
        }
  

到这里,两个文本框都已经加载到各自的数据。剩下的就是动态联动了。

4、当我们更改第一个下拉框中的内容后,会触发第一个文本框的SelectedIndexChanged事件。将第一个下拉框的proID(省的ID)作为参数,即可查到其市的内容。

具体代码如下:

 protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
        {
            //省的ID
            string proID = this.DropDownList1.SelectedValue;
            SqlConnection con = DB.createConnection();
            con.Open();

            SqlCommand cmd = new SqlCommand("select * from city where proID=" + proID, con);
            SqlDataReader sdr = cmd.ExecuteReader();
            //绑定
            this.DropDownList2.DataSource = sdr;
            this.DropDownList2.DataTextField = "cityName";
            this.DropDownList2.DataValueField = "cityID";
            this.DropDownList2.DataBind();
            sdr.Close();
            con.Close();
        }


       这样,我们就可以实现动态联动了。这样的动态联动,一般由多个下拉框组成一组菜单,比如上面用到的两个下拉框。下拉菜单之间有联动的关系。当上级的选中项发生改变时,下级会根据上级中的选中项显示相应的内容。

      虽然只是一个小技巧或者说是小的需求,但当数据量特别大时,它的功能就不可小视了。上次期末考试导考生的时候,可能只是一个页面忽略了这个功能,结果导致工作量大大增加。

      用了动态联动之后,当面对庞大的数据或复杂的分类时,页面的加载速度也不会受到影响,也方便了用户查找。


  • 11
    点赞
  • 41
    收藏
    觉得还不错? 一键收藏
  • 13
    评论
ASP.NET框架中实现下拉框联动可以使用Jquery来实现。首先,你可以创建一个控制器方法来获取某个省份的所有城市数据。在这个方法中,你可以使用Jquery的Ajax方法来发送异步请求,并返回城市数据。\[2\]接着,在前端页面中,你可以使用Jquery的change事件来监听省份下拉框的选择变化,当选择变化时,触发Ajax请求获取对应省份的城市数据,并将数据填充到城市下拉框中。这样就实现下拉框联动效果。\[1\] 以下是一个简单的示例代码: 在控制器中: ```csharp public ActionResult GetCityList(int id) { if (!Request.IsAjaxRequest()) { return Content("请不要非法方法,这是不道德的行为!"); } BLL.Province bll = new MvcBBS.BLL.Province(); List<MvcBBS.Model.S_City> modellist = bll.GetCityList(id); return Json(modellist); } ``` 在前端页面中: ```html <select id="province"> <option value="1">省份1</option> <option value="2">省份2</option> <!-- 其他省份选项 --> </select> <select id="city"> <!-- 根据选择的省份动态生成城市选项 --> </select> <script> $(document).ready(function() { $("#province").change(function() { var provinceId = $(this).val(); $.ajax({ url: "/Controller/GetCityList", type: "GET", data: { id: provinceId }, success: function(data) { var cityOptions = ""; $.each(data, function(index, city) { cityOptions += "<option value='" + city.Id + "'>" + city.Name + "</option>"; }); $("#city").html(cityOptions); } }); }); }); </script> ``` 这样,当选择省份下拉框的选项时,城市下拉框会根据选择的省份动态生成对应的城市选项。\[1\] #### 引用[.reference_title] - *1* *2* *3* [ASP.NET MVC + Jquery 实现Ajax下拉框数据三级联动](https://blog.csdn.net/lchwhy/article/details/7438522)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值