省市区联动下拉效果在WEB中应用非常广泛,尤其在一些会员信息系统、电商网站最为常见。开发者一般使用Ajax实现无刷新下拉联动。本文将讲述,利用jQuery插件,通过读取JSON数据,实现无刷新动态下拉省市二(三)级联动效果。
- <label>
- <span>住址(省市区):</span>
- @Html.DropDownList("Province",ViewData["Province"] as SelectList,"请选择",new { @class = "m-wrap small" })
- @Html.DropDownList("City",ViewData["City"] as SelectList,new { @class = "m-wrap small" })
- @Html.DropDownList("Area",ViewData["Area"] as SelectList,new { @class = "m-wrap small" })
- </label>
- <label>
- <span>住址(省市区):</span>
- <select class="m-wrap small" id="Province" name="Province"><option value="">请选择</option>
- <option value="110000">北京</option>
- <option value="120000">天津</option>
- <option value="130000">河北</option>
- <option value="140000">山西</option>
- <option value="150000">内蒙古</option>
- <option value="160000">辽宁</option>
- <option value="170000">吉林</option>
- <option value="180000">黑龙江</option>
- <option value="190000">上海</option>
- <option value="200000">江苏</option>
- <option value="210000">浙江</option>
- <option value="220000">安徽</option>
- <option value="230000">福建</option>
- <option value="240000">江西</option>
- <option value="250000">山东</option>
- <option value="260000">河南</option>
- <option value="270000">湖北</option>
- <option value="280000">湖南</option>
- <option value="290000">广东</option>
- <option value="300000">广西</option>
- <option value="310000">海南</option>
- <option value="320000">重庆</option>
- <option value="330000">四川</option>
- <option value="340000">贵州</option>
- <option value="350000">云南</option>
- <option value="360000">西藏</option>
- <option value="370000">陕西</option>
- <option value="380000">甘肃</option>
- <option value="390000">青海</option>
- <option value="400000">宁夏</option>
- <option value="410000">新疆</option>
- <option value="420000">香港</option>
- <option value="430000">澳门</option>
- <option value="440000">台湾</option>
- </select>
- <select class="m-wrap small" id="City" name="City"><option value="">请选择</option>
- </select>
- <select class="m-wrap small" id="Area" name="Area"><option value="">请选择</option>
- </select>
- </label>
- <script type="text/javascript">
- $(document).ready(function () {
- var Province = $("#Province").val();
- var City = $("#City").val()
- if (Province != "" && City=="") {
- setCity();
- }
- if (City != "" && $('#Area').val() == "") {
- setArea();
- }
- $("#Province").change(function () {
- setCity();
- });
- $("#City").change(function () {
- setArea();
- });
- function setCity() {
- $('#City').html('').append($("<option value=''>请选择</option>"));
- $('#Area').html('').append($("<option value=''>请选择</option>"));
- if($("#Province").val()!=""){
- $.getJSON('@Url.Action("GetCitys")',{ code: $("#Province").val() },function (data) {
- $.each(data,function (i,item) {
- $('#City').append($("<option></option>").val(item.code).html(item.name));
- });
- setArea();
- });
- }
- }
- function setArea() {
- $('#Area').html('').append($("<option value=''>请选择</option>"));
- if($("#City").val()!=""){
- $.getJSON('@Url.Action("GetAreas")',{ code: $("#City").val() },function (data) {
- $.each(data,item) {
- $('#Area').append($("<option></option>").val(item.code).html(item.name));
- });
- });
- }
- }
- });
- </script>
- [AuthorizeIgnore]
- public JsonResult GetCitys(string code)
- {
- var city = AreaService.GetCities(code);
- return Json(city.ToList<City>(),JsonRequestBehavior.AllowGet);
- }
- [AuthorizeIgnore]
- public JsonResult GetAreas(string code)
- {
- var area = AreaService.GetAreas(code);
- JsonResult json = Json(area.ToList<Area>(),JsonRequestBehavior.AllowGet);
- return json;
- }
- public void InitViewData(ClientRequest request)
- {
- List<SelectListItem> list = new List<SelectListItem> {
- new SelectListItem { Text = "全部",Value = "-1",Selected = (request.IsActive==-1 ? true : false)},new SelectListItem { Text = "是",Value = "1",Selected = (request.IsActive==1 ? true : false)},new SelectListItem { Text = "否",Value = "0",Selected = (request.IsActive==0 ? true : false) } };
- ViewData["IsActive"] = list;
- var provance = this.AreaService.GetProvinces();
- ViewData["Province"] = from a in provance
- select new SelectListItem
- {
- Text = a.name,Value = a.code,Selected = request.Province == a.code ? true: false
- };
- List<SelectListItem> City = new List<SelectListItem>();
- ViewData["City"] = City;
- if (request.City != null)
- {
- var city = this.AreaService.GetCities(request.Province);
- ViewData["City"] = from a in city
- select new SelectListItem
- {
- Text = a.name,Selected = request.City == a.code ? true : false
- };
- }
- List<SelectListItem> Area = new List<SelectListItem>();
- ViewData["Area"] = Area;
- if (request.Area != null)
- {
- var area = this.AreaService.GetAreas(request.City);
- ViewData["Area"] = from a in area
- select new SelectListItem
- {
- Text = a.name,Selected = request.Area == a.code ? true : false
- };
- }
- }