Jquery+Ajax下拉框级联查询

Jquery代码

<script type="text/javascript">
          $(function(){

//提交事件
           $("#ImageButton1").click(function(){

//省Id
        var provinceId=$("#selProvince").val();

//市Id
        var cityId=$("#selCity").val();
        //区县Id

var districtId=$("#selDistrict").val();
        //把省市区ID赋值到隐藏域

$("#hidProvince").attr("value",provinceId);
         $("#hidCity").attr("value",cityId);
          $("#hidDistrict").attr("value",districtId);
          });
            //加载地区
         var area=$("#hidArea").val();  //后台将(省,市,区)ID放到隐藏域hidArea
//         alert(area);
         loadArea(0,0,area);//Ajax方法查询默认(北京,北京,朝阳)
         $("#selProvince").change(function(){//存放省的下拉框发生变化时调用Ajax
        loadArea(this.value,1,"");
        });
        $("#selCity").change(function(){//存放市的下拉框发生变化时调用Ajax
        loadArea(this.value,2,"");
         });

//id:省(0)市县id,type:0为省,1为市,2县,area:北京,北京,朝阳区
function loadArea(id,type,area){
    $.ajax({
        type:"get",
        url:"/ashx/GetArea.ashx",
        data:{Id:id,type:type},
        dataType:"json",
        success:function(data){
            var str="";
            var areaArr=area.split(",");
            if(type==0){
                $.each(data,function(i,item){
                    str=str+"<option value=\""+item.Id+"\">"+item.Name+"</option>";
                })
                var selProvince=$("#selProvince");
                selProvince.html(str);
                if(areaArr[0])
                {
                    selProvince.val(areaArr[0]);
                }
                loadArea(selProvince.val(),1,area);
            }
            if(type==1){
                $.each(data,function(i,item){
                    str=str+"<option value=\""+item.Id+"\">"+item.Name+"</option>";
                })
                var selCity=$("#selCity");
                selCity.html(str);
                if(areaArr[1])
                {
                    selCity.val(areaArr[1]);
                }
                loadArea(selCity.val(),2,area);
            }
            if(type==2){
                $.each(data,function(i,item){
                    str=str+"<option value=\""+item.Id+"\">"+item.Name+"</option>";
                })
                var selDistrict=$("#selDistrict");
                selDistrict.html(str);
                if(areaArr[2])
                {
                    selDistrict.val(areaArr[2]);
                }
                //$("#selDistrict")
            }
        }
        
    });
    }
        </script>



aspx页面代码

<div class="ptop1">填写联系地址:<span class="spanlv">*</span></div>
                <div class="ptop2">
                 <select id="selProvince" runat="server">
                </select>
                <select id="selCity" runat="server">
                </select>
                <select id="selDistrict" runat="server">
                </select>

<input type="hidden" id="hidArea" value="" runat="server" />
                <input type="hidden" runat="server" id="hidProvince" />
                <input type="hidden" runat="server" id="hidCity" />
                <input type="hidden" runat="server" id="hidDistrict" />
             
             </div>



一般处理程序 源码

using System;
using System.Collections;
using System.Data;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;
using System.Xml.Linq;
using BLL;
using Newtonsoft.Json;
using System.Collections.Generic;
using Model;
using Common;
using Model.Linq;

namespace Web.ashx
{
    /// <summary>
    /// $codebehindclassname$ 的摘要说明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    public class GetArea : IHttpHandler
    {

public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            int id = 0;
            string strId = context.Request.QueryString["Id"];
            //类型:省0,市1,县2
            string type = context.Request.QueryString["type"];
            if (!string.IsNullOrEmpty(strId))
            {
                id = Convert.ToInt32(strId);
            }
            phDataContext ph = new phDataContext();
            string result = "";
            if (type == "0")
            {
                result = ConvertHelper.DataToJson(ph.Province.Select(p=> new { p.Id, p.Name}));
                context.Response.Write(result);
            }
            if (type == "1")
            {
                result = ConvertHelper.DataToJson(ph.City.Where(c => c.ProvinceId == id).Select(c => new { c.Id,c.Name }));
                context.Response.Write(result);
            }
            if (type == "2")
            {
                result = ConvertHelper.DataToJson(ph.District.Where(c => c.CityId == id).Select(d => new { d.Id, d.Name }));
                context.Response.Write(result);
            }
            //context.Response.Write(result);
        }

public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}



后台代码

//这个就是给hidArea隐藏域赋值

if (!pm01.Area.IsNullOrEmptyOrWhiteSpace())
                    {
                        //this.hidArea.Value = pm01.Area;
                        hidArea.Value = pm01.ProvinceId + "," + pm01.CityId + "," + pm01.DistrictId;
                    }

自从用了ajax就停不下来了  (ˇ?ˇ) 想~



Jquery+Ajax下拉框级联查询

时间: 2024-10-17 04:56:30

Jquery+Ajax下拉框级联查询的相关文章

Java Swing应用程序 JComboBox下拉框联动查询

在web项目中,通过下拉框.JQuery和ajax可以实现下拉框联动查询. 譬如说,当你查询某个地方时,页面上有:省份:<下拉框省份> 市区:<下拉框市区> 县乡:<下拉框县乡> 街道:<街道下拉框> 查询 譬如说,你选择了省:江苏省,那么在市区中只会显示江苏省的市区 譬如:(网上的图) 具体详细实现可以参考,写得挺好的:http://blog.csdn.net/sinat_24491773/article/details/50810471 那么在swing

JQuery打造下拉框联动效果

做联动效果,若是用纯JavaScript来做,往往须要辅助页面保存须要刷新的结果集,然后渲染到原页面.考虑将须要动态刷新的内容自己主动拼接到前一个下拉框之后,当前一个下拉框onchange后,同级的后面的下拉框所有清除,然后又一次拼接刷新的内容.用JQuery实现比較easy,代码以省市联动效果为例实现. JSP页面代码例如以下: <li id="base"> <p>生源地:</p> <label> <select id="

js,jquery获取下拉框选中的option

js获取select选中的值: var sel=document.getElementById("select1"); var index = sel.selectedIndex; // 选中索引 albumid= sel.options[index].value;//要的值 jQuery获取下拉框选中的option: $("#s option:selected").val();

jQuery切换下拉框里面对应的div

<!DOCTYPE html><html>      <head>            <meta charset="UTF-8">            <title>jquery实现下拉框选中对应的div</title>            <script src="http://code.jquery.com/jquery-1.8.0.min.js"></script

jquery获得下拉框值的代码

jquery获得下拉框值的代码 获取Select : 获取select 选中的 text : $("#ddlRegType").find("option:selected").text(); 获取select选中的 value: $("#ddlRegType ").val(); 获取select选中的索引: $("#ddlRegType ").get(0).selectedIndex; 设置select: 设置select 选

基于jQuery select下拉框美化插件

今天给大家分享一款基于jQuery select下拉框美化插件,这款插件适用浏览器:IE8.360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗.  <table>         <tr>             <td>                 <h2>                     演示1</h2>                 <select name="drop1&qu

Jquery操作下拉框(DropDownList)实现取值赋值

Jquery操作下拉框(DropDownList)想必大家都有所接触吧,下面与大家分享下对DropDownList进行取值赋值的实现代码 1. 获取选中项: 获取选中项的Value值: $('select#sel option:selected').val(); 或者 $('select#sel').find('option:selected').val(); 获取选中项的Text值: $('select#seloption:selected').text(); 或者 $('select#sel

jquery 获取下拉框值与select text

下面先介绍了很多jquery获取select属性的方法,同时后面的实例我们讲的是jquery 获取下拉框值与select text代码. 下面先介绍了很多jquery获取select属性的方法,同时后面的实例我们讲的是jquery 获取下拉框值与select text代码. jquery获取select选择的文本与值 获取select : 获取select 选中的 text : $("#ddlregtype").find("option:selected").tex

jQuery实现下拉框选择图片的功能

让下拉框中显示图片,并可选择对应图片,让select下拉框不仅可显示文字,还可以显示图片内容.为了更生动些,这里还加入了jQuery动画效果,当展开Select列表的时候,图片渐变显示.使用了一个jQ插件:imageselect.js,使用效果的朋友可以自己下载吧. <!DOCTYPE html> <head> <title>支持图片选择的jQuery列表框插件imageselect.js</title> <script type="text