1.效果图 

2.联动js

 /**
* jquery.choosearea.js - 地区联动封装
*/
; (function ($) {
var choosearea = function (options) {
this.set = $.extend({
dataUrl: "/Content/Js/city_code.js",
selectDomId: {
province: "a",
city: "b",
county: "c"
},
data: null,
initAreaIds: {
Province: 0,
City: 0,
County: 0
},
eventInterface: {
renderProvinceList: function (list, selectedId) {
this.jq_province.empty().append($(this.ProvinceListHtml(list, selectedId, "请选择省")));
},
renderCityList: function (list, selectedId, isInit) {
var city = this.jq_city;
isInit = typeof (isInit) == "undefined" ? false : true;
city.empty().append($(this.CityListHtml(list, selectedId, "请选择市")));
},
renderCountyList: function (list, selectedId, isInit) {
var optionsHtml = this.CountyListHtml(list, selectedId, "请选择县");
var county = this.jq_county;
isInit = typeof (isInit) == "undefined" ? false : true;
county.empty().append($(optionsHtml));
},
onchanged: function (cityId) { }
} }, options);
this.provinceList = [];
this.cityList = [];
this.countyList = [];
this.jq_province = $("#" + this.set.selectDomId.province);
this.jq_city = $("#" + this.set.selectDomId.city);
this.jq_county = $("#" + this.set.selectDomId.county);
this._init();
};
choosearea.prototype = {};
choosearea.fn = choosearea.prototype;
choosearea.fn._init = function () {
var _this = this;
$.get(_this.set.dataUrl, {}, function (datajson) {
_this.set.data = datajson
_this._setAreaList();
_this._initRender(_this.set.initAreaIds.Province, _this.set.initAreaIds.City, _this.set.initAreaIds.County);
_this._initEvents();
}, "json");
};
//设置地区列表
choosearea.fn._setAreaList = function () {
this.provinceList = this.set.data.provinceList;
this.cityList = this.set.data.cityList;
this.countyList = this.set.data.countyList;
}; //初始化渲染
choosearea.fn._initRender = function (provinceId, cityId, countyId) { this.set.eventInterface.renderProvinceList.call(this, this.provinceList, provinceId);
var cityList = $.grep(this.cityList, function (n, i) {
return n.ProID == provinceId;
});
this.set.eventInterface.renderCityList.call(this, cityList, cityId, true);
var countyList = $.grep(this.countyList, function (n, i) {
return n.CityID == cityId;
});
this.set.eventInterface.renderCountyList.call(this, countyList, countyId, true);
}; //渲染列表
choosearea.fn.ProvinceListHtml = function (list, selectedId, firstTips) {
firstTips = firstTips || "";
var selectedAttr = selectedId == 0 ? " selected='selected'" : "";
var optionsHtml = firstTips != "" ? "<option value='0' " + selectedAttr + ">" + firstTips + "</option>" : ""; if (typeof (list) != "undefined") {
$.each(list, function (i, city) {
var selAttr = selectedId == city.ProID ? " selected='selected'" : "";
optionsHtml += "<option value='" + city.ProID + "' " + selAttr + ">" + city.ProName + "</option>";
});
};
return optionsHtml;
};
//渲染列表
choosearea.fn.CityListHtml = function (list, selectedId, firstTips) {
firstTips = firstTips || "";
var selectedAttr = selectedId == 0 ? " selected='selected'" : "";
var optionsHtml = firstTips != "" ? "<option value='0' " + selectedAttr + ">" + firstTips + "</option>" : ""; if (typeof (list) != "undefined") {
$.each(list, function (i, city) {
var selAttr = selectedId == city.CityID ? " selected='selected'" : "";
optionsHtml += "<option value='" + city.CityID + "' " + selAttr + ">" + city.CityName + "</option>";
});
};
return optionsHtml;
};
//渲染列表
choosearea.fn.CountyListHtml = function (list, selectedId, firstTips) {
firstTips = firstTips || "";
var selectedAttr = selectedId == 0 ? " selected='selected'" : "";
var optionsHtml = firstTips != "" ? "<option value='0' " + selectedAttr + ">" + firstTips + "</option>" : "";
//console.log(list);
if (typeof (list) != "undefined") {
$.each(list, function (i, city) {
var selAttr = selectedId == city.Id ? " selected='selected'" : "";
optionsHtml += "<option value='" + city.Id + "' " + selAttr + ">" + city.DisName + "</option>";
});
};
return optionsHtml;
};
//初始化事件
choosearea.fn._initEvents = function () {
var province = this.jq_province;
var city = this.jq_city;
var county = this.jq_county;
var _this = this;
province.change(function () {
var id = parseInt($(this).val());
var cityList = $.grep(_this.cityList, function (n, i) {
return n.ProID == id;
});
_this.set.eventInterface.renderCityList.call(_this, cityList, 0);
_this.set.eventInterface.renderCountyList.call(_this, [], 0, false);
}); city.change(function () {
var id = parseInt($(this).val());
var countyList = $.grep(_this.countyList, function (n, i) {
return n.CityID == id;
});
_this.set.eventInterface.renderCountyList.call(_this, countyList, 0, false);
});
};
$.choosearea = choosearea;
})(jQuery);

3.json数据

http://files.cnblogs.com/files/youngerliu/city_code.js

4.使用方法

  默认选择

new $.choosearea({
selectDomId: {
province: "selProvince",
city: "selCity",
county: "selCounty"
},
initAreaIds: {Province:"0",City:"0",County:"0"}
});

  指定选择

   new $.choosearea({
selectDomId: {
province: "selProvince",
city: "selCity",
county: "selCounty"
},
initAreaIds: {Province:"1",City:"1",County:"9"}
});

省市县三级联动(jqurey+json)的更多相关文章

  1. 将省市县三级联动的json数据,转化为element-ui能用的格式,并使用

    var options=[]; var cities = { '北京': { '北京': ['东城区', '西城区', '崇文区', '宣武区', '朝阳区', '丰台区', '石景山区', '海淀区 ...

  2. android:省市县三级联动(基于json和spring)

    一.请看效果图": 二.程序的代码: 1.MainActivity.java package com.loveplusplus.loader.demo.ui; import org.json ...

  3. wex5 实战 省市县三级联动与地址薄同步

    无论是商城,还是快递,都要用到省市县三级联动,和地址薄,今天就以实战来制作,难点有3个: 1:三级联动,有wex5组件实现,相对简单,实战里对行数据进行了拼接 2:  地址薄选项,利用inputSel ...

  4. Android 省市县 三级联动(android-wheel的使用)[转]

    转载:http://blog.csdn.net/lmj623565791/article/details/23382805 今天没事跟群里面侃大山,有个哥们说道Android Wheel这个控件,以为 ...

  5. Android 省市县 三级联动(android-wheel的使用)

    转载请注明出处:http://blog.csdn.net/lmj623565791/article/details/23382805 今天没事跟群里面侃大山,有个哥们说道Android Wheel这个 ...

  6. php仿经典省市县三级联动

    之前有个需求要写个类似省市县三级联动的页面,于是,网上找了点资料看了下,其实原理很简单: 当我们选择一级栏目中某条记录的时候,会获取该栏目的vaule值,并发起ajax请求,后台根据这个vaule值, ...

  7. 项目总结01:JSP mysql SpringMvc下中国省市县三级联动下拉框

    JSP mysql SpringMvc下中国省市县三级联动下拉框 关键词 JSP  mysql数据库  SpringMvc  ajax   Controller层  Service层  中国地区  省 ...

  8. jQuery - 全国省市县三级联动

    最近有空用jquery做了一个全国省市县的三级联动,在以后或许可以用的到 ,遗憾的是我还没用封装,等有空看能不能封装成一个插件 废话不多说,贴上代码: <!doctype html> &l ...

  9. 省市县三级联动 sql语句

    发现在网上的省市县三级联动大部分是mysql的.就算是sqlserver的,也不准确.于是就把mysql的给改了下,适用sqlserver.sql语句如下: CREATE TABLE Dic_Area ...

随机推荐

  1. iOS推送小结(证书的生成、客户端的开发、服务端的开发)

    1.推送过程简介 1.1.App启动过程中,使用UIApplication::registerForRemoteNotificationTypes函数与苹果的APNS服务器通信,发出注册远程推送的申请 ...

  2. Android 敏感 API 的说明

    从中国的国情来看,Google 的诸多产品,包括 gmail,Android 官方市场 Google Play 正处于并将长期处于访问不了的状态.国内几亿网民也要生活,于是墙内出现了“百家争鸣”的场面 ...

  3. ExtJs服务器端代理(Ajax)

    服务器端代理: Ajax:在当前域中发送请求 JsonP:跨域的请求 Rest:与服务器进行RESTful(GET/PUT/POST/DELETE)交互 Direct:使用  Ext.direct.M ...

  4. 题目:求1+2+…+n,

    题目:求1+2+-+n, 要求不能使用乘除法.for.while.if.else.switch.case等关键字 以及条件判断语句(A?B:C). java 实现 public class sum { ...

  5. vue-loader配合webpack的使用及安装

    vue-loader配合webpack的使用及安装: 工程文件简单的目录结构 index.html main.js   入口文件 App.vue   vue文件,官方推荐命名法 package.jso ...

  6. 【LFS】简易LFS搭建指南

    http://blog.csdn.net/u012333520/article/details/50533002#comments ////////////////////////////////// ...

  7. 使用Packet Sniffer抓包和分析(z-stack协议)

    以下内容仅是自己学习总结,可能会有错误,有发现问题的欢迎指正(图片可以自己放大,还是比较清晰的). 1.协调器上电,其他设备均不上电,抓包如下: 通过观察可以发现,协调器建立网络成功后,会以15秒为周 ...

  8. HRPlugin For Xcode发布(附源码地址)

    今天给大家介绍的这个插件,是我在IOS平台上开发以来,一些想法的集合体.因为本人时常感觉在开发过程中无论从GOOGLE资料查找和SQL数据库查询,正则表达式测试,SVN等,这些经常要做的操作中,耽误了 ...

  9. ListAdapter列表适配器

    ListAdapter列表适配器其实是继承了BaseAdapter 示例图: MainActivity package com.shaoxin.mylistadapter; import androi ...

  10. Linux学习笔记(8)-exec族函数

    昨天学习了Linux下的进程创建,创建一个进程的方法极为简单,只需要调用fork函数就可以创建出一个进程,但是-- 介绍fork()函数的时候提到,在创建进程后,子进程与父进程有相同的代码空间,执行的 ...