如何做一个级联效果的,城市选择插件

本贴最后更新于 4250 天前,其中的信息可能已经天翻地覆

(一)场景

          老大安排我弄一个城市选择插件,用在公司系统。

(二)准备工作

         最主要的就是数据了,去几个网站逛了一圈,感觉京东的不错,于是就想办法把里面的数据拉下来。京东页面 ,其实很简单,用google浏览器自带的功能,捕捉下http包,查看下request的请求url,就可以看出,每一次请求,按参数返回json,然后组装显示在页面,几个js方法就可以了。然后再后台,服务器启动的时候,将这些数据从数据库查询出来放入内存中,(便于提高速度)。然后每次请求直接从内存中的数据结构拉下来就行。

1、写方法拉京东数据。

<script type="text/javascript">
	$(document).ready(function(){
		//根据市查询县
		function country(z){
			var st="";
			$.getJSON("http://buy.jd.com/purchase/flows/easybuy/FlowService.ashx?&action=GetCountys&Id="+z+"&callback=?", function(data){
				var Are= data.Obj.Areas;
				for (var x in Are){
					st +="insert into qly_bd_region (regionid,regionfid,regiontype,regionname)values('"+Are[x].Id+"' ,'"+z+"','县','"+Are[x].Name+ "');<br/>" ;	
				}
				$("#hh").append(st);
			});
		}
		//根据省id去查询对应的市
			function test(j){
				$.getJSON("http://buy.jd.com/purchase/flows/easybuy/FlowService.ashx?action=GetCitys&Id="+j+"&callback=?", function(data){
					var Areas = data.Obj.Areas;
					//console.log(Areas);
					var str="";
					for(var i in Areas ){
str +=&quot;insert into qly_bd_region (regionid,regionfid,regiontype,regionname)values('&quot;+Areas[i].Id+&quot;' ,'&quot;+j+&quot;','市','&quot;+Areas[i].Name+ &quot;');&lt;br/&gt;&quot; ; setInterval(country(Areas[i].Id),1000); } $(&quot;#divs&quot;).append(str); }); } //这里的i主要表示省id for( var i =1;i&lt;32;i++){ setInterval(test(42),1000); } });</pre>

以上是查询京东数据,然后直接封装成sql。(这里要注意的是json和jsonp的区别,如果用普通的ajax方法会被服务器拒绝)

2、建数据库表

REGION

3、现在可以写后台处理方法了,封装了数据结构了

helper帮助类

package com.qly.b2b.config;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.ibatis.session.SqlSession;
import org.apache.log4j.Logger;

import com.qly.b2b.dao.config.RegionMapper;
import com.qly.b2b.model.config.Region;
import com.qly.b2b.mybatisconn.DbHelper;

public class RegionHelper {
/** 日志组件 **/
private static Logger log = Logger.getLogger(SysConfigHelper.class);

/** 数据缓存是否加载完毕 **/ private static boolean loaded = false; /** 所有省信息 **/ private static List&lt;Region&gt; provinceList = new ArrayList&lt;Region&gt;(); /** 按省划分的市信息 **/ private static Map&lt;Integer, List&lt;Region&gt;&gt; cityMap = new HashMap&lt;Integer, List&lt;Region&gt;&gt;(); /** 按市划分的区县信息 **/ private static Map&lt;Integer, List&lt;Region&gt;&gt; countyMap = new HashMap&lt;Integer, List&lt;Region&gt;&gt;(); /** 所有地域信息 **/ private static Map&lt;Integer, Region&gt; regionMap = new HashMap&lt;Integer, Region&gt;(); /** 禁止实例化 */ private RegionHelper() { } /** * * load(进行数据初始化) (这里描述这个方法适用条件 – 可选) * * @param force * 是否强制加载,用于重新初始化数据 void * @exception */ private static synchronized void load(boolean force) { // 如果非强制初始化(重新初始化),并且已经初始化完毕,返回 if (loaded &amp;&amp; !force) { return; } log.info(&quot;========================== 加载全国地址静态配置信息到缓存开始 ==========================&quot;); loaded = false; provinceList.clear(); cityMap.clear(); countyMap.clear(); regionMap.clear(); // 从数据库中获取数据 List&lt;Region&gt; list = getAllRegion(); // 将数据加载到缓存 for (Region region : list) { if (&quot;1&quot;.equals(region.getRegiontype())) { provinceList.add(region); } else if (&quot;2&quot;.equals(region.getRegiontype())) { List&lt;Region&gt; cityList = getListFromMap(region.getRegionfid(), cityMap); cityList.add(region); } else if (&quot;3&quot;.equals(region.getRegiontype())) { List&lt;Region&gt; countyList = getListFromMap(region.getRegionfid(), countyMap); countyList.add(region); } regionMap.put(region.getRegionid(), region); } loaded = true; log.info(&quot;========================== 加载全国地址静态配置信息到缓存结束 ==========================&quot;); } /** * getAllRegion(从数据库获取所有地域信息) * (这里描述这个方法适用条件 – 可选) * @return * List&lt;Region&gt; * @exception */ private static List&lt;Region&gt; getAllRegion() { SqlSession sqlSession = DbHelper.getSqlSession(); RegionMapper mapper = sqlSession.getMapper(RegionMapper.class); List&lt;Region&gt; list = mapper.getAllRegion(); sqlSession.close(); return list; } /** * getListFromMap(根据地域父ID从 Hash map 中获取对应 List) * (这里描述这个方法适用条件 – 可选) * @param regionfid * @param map * @return * List&lt;Region&gt; * @exception */ private static List&lt;Region&gt; getListFromMap(Integer regionfid, Map&lt;Integer, List&lt;Region&gt;&gt; map) { if (map.containsKey(regionfid)) { return map.get(regionfid); } else { List&lt;Region&gt; list = new ArrayList&lt;Region&gt;(); map.put(regionfid, list); return list; } } /** * * reload(重新加载数据) (这里描述这个方法适用条件 – 可选) void * * @exception */ public static void reload() { load(true); } /** * getProvinceList(这里用一句话描述这个方法的作用) * (这里描述这个方法适用条件 – 可选) * @return * List&lt;Region&gt; * @exception */ public static List&lt;Region&gt; getProvinceList() { if (!loaded) { load(false); } return provinceList; } /** * 根据省id,拿到对应的城市信息 */ public static List&lt;Region&gt; getCityList(Integer provinceId) { if (!loaded) { load(false); } return cityMap.get(provinceId); } /** * 根据市id拿到对应的县 * * @param cityId * @return */ public static List&lt;Region&gt; getCountyMap(Integer cityId) { if (!loaded) { load(false); } return countyMap.get(cityId); } /** * getRegion(根据地域ID获取地域信息) * (这里描述这个方法适用条件 – 可选) * @param regionId * @return * Region * @exception */ public static Region getRegion(Integer regionId) { if (!loaded) { load(false); } return regionMap.get(regionId); }

}

controller类

@Controller
@RequestMapping("/region")
public class RegionController extends BaseController {
@RequestMapping(value = &quot;/getallprovince&quot;) @ResponseBody public ModelMap getallprovince(HttpServletRequest request, ModelMap modelMap) throws Exception { List&lt; Region&gt; provincelist = RegionHelper.getProvinceList(); modelMap.put(&quot;provincelist&quot;, provincelist); return modelMap; } @RequestMapping(value = &quot;/getcity&quot;) @ResponseBody public ModelMap getcity(HttpServletRequest request, ModelMap modelMap) throws Exception { List&lt; Region&gt; citylist = RegionHelper.getCityList(Integer.parseInt(request.getParameter(&quot;id&quot;))); modelMap.put(&quot;citylist&quot;, citylist); return modelMap; } @RequestMapping(value = &quot;/getcounty&quot;) @ResponseBody public ModelMap getcounty(HttpServletRequest request, ModelMap modelMap) throws Exception { List&lt; Region&gt; countylist = RegionHelper.getCountyMap(Integer.parseInt(request.getParameter(&quot;id&quot;))); modelMap.put(&quot;countylist&quot;, countylist); return modelMap; }

}

4、处理前台js展现

$(document).ready(function(){
	//获得省列表,初始化第一个 select
	$.getJSON(basepath+"/region/getallprovince", function(data){
	  setOptions("province", data.provincelist);
	});
});

//获取城市列表
function getCitys(){
setAddress();

var cityid = $(&quot;#province&quot;).find(&quot;option:selected&quot;).val(); if (cityid == &quot;&quot;) { clearSelect(&quot;city&quot;); return; } $.getJSON(basepath+&quot;/region/getcity&quot;,{id:cityid}, function(data){ setOptions(&quot;city&quot;, data.citylist); }); //清空地区列表 clearSelect(&quot;county&quot;);

// });
}

//获取地区列表
function getAreas(){
setAddress();
var countyid = $("#city").find("option:selected").val();
if (countyid == "")
{
clearSelect("county");
return;
}
$.getJSON(basepath+"/region/getcounty",{id:countyid}, function(data){
setOptions("county", data.countylist);
});
}

//清空下拉列表
function clearSelect(id){
$("#" + id).empty() ;
$("#" + id).append("<option value=''>请选择</option>");
}

//将数据放到指定 select 中
function setOptions(id, datas) {
$("#" + id).empty() ;
$("#" + id).append("<option value=''>请选择</option>");
for (var i in datas )
{
$("#" + id).append("<option value='" + datas[i].regionid + "'>" + datas[i].regionname + "</option>");
}
}

function setAddress(){
var address = getOptionName("province") + getOptionName("city") + getOptionName("county");
$("#address1").html(address);
var address1 = $("#address1").text();
$("#provinceaddress").val(address1);
}

function getOptionName(id) {
if($("#" + id).find("option:selected").val() != ""){
return $("#" + id).find("option:selected").html();
}

return &quot;&quot;;

}

<select name="province" id="province" onchange="getCitys()">
<option value=''>请选择</option>
</select> <select name="city" id="city" onchange="getAreas()">
<option value=''>请选择</option>
</select> <select name="county" id="county"
onchange="setAddress()">
<option value=''>请选择</option>
</select>

<span id="address1"></span></span>

5、到此为止,一个js城市选择的插件就ok了

(三)技术点

      主要是封装数据结构,和获取数据。

(四)检查数据

SELECT a.regionid,a.regionname, b.regionid,b.regionname FROM qly_bd_region a LEFT JOIN qly_bd_region b ON b.regionfid = a.regionid WHERE b.regionid IS  NULL AND a.regiontype IN (1,2)

这条sql语句可以帮助你,数据是否正确。主要用了左连接,然后id和fid就可以找出数据是否缺失

  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    730 引用 • 1280 回帖 • 5 关注
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 734 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 1 关注
  • Firefox

    Mozilla Firefox 中文俗称“火狐”(正式缩写为 Fx 或 fx,非正式缩写为 FF),是一个开源的网页浏览器,使用 Gecko 排版引擎,支持多种操作系统,如 Windows、OSX 及 Linux 等。

    7 引用 • 30 回帖 • 385 关注
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    6 引用 • 142 回帖 • 1 关注
  • PWL

    组织简介

    用爱发电 (Programming With Love) 是一个以开源精神为核心的民间开源爱好者技术组织,“用爱发电”象征开源与贡献精神,加入组织,代表你将遵守组织的“个人开源爱好者”的各项条款。申请加入:用爱发电组织邀请帖
    用爱发电组织官网:https://programmingwithlove.stackoverflow.wiki/

    用爱发电组织的核心驱动力:

    • 遵守开源守则,体现开源&贡献精神:以分享为目的,拒绝非法牟利。
    • 自我保护:使用适当的 License 保护自己的原创作品。
    • 尊重他人:不以各种理由、各种漏洞进行未经允许的抄袭、散播、洩露;以礼相待,尊重所有对社区做出贡献的开发者;通过他人的分享习得知识,要留下足迹,表示感谢。
    • 热爱编程、热爱学习:加入组织,热爱编程是首当其要的。我们欢迎热爱讨论、分享、提问的朋友,也同样欢迎默默成就的朋友。
    • 倾听:正确并恳切对待、处理问题与建议,及时修复开源项目的 Bug ,及时与反馈者沟通。不抬杠、不无视、不辱骂。
    • 平视:不诋毁、轻视、嘲讽其他开发者,主动提出建议、施以帮助,以和谐为本。只要他人肯努力,你也可能会被昔日小看的人所超越,所以请保持谦虚。
    • 乐观且活跃:你的努力决定了你的高度。不要放弃,多年后回头俯瞰,才会发现自己已经成就往日所仰望的水平。积极地将项目开源,帮助他人学习、改进,自己也会获得相应的提升、成就与成就感。
    1 引用 • 487 回帖 • 2 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    325 引用 • 1395 回帖 • 1 关注
  • 创业

    你比 99% 的人都优秀么?

    82 引用 • 1395 回帖
  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    168 引用 • 597 回帖
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 1 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 46 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 1 关注
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    86 引用 • 165 回帖
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖
  • 笔记

    好记性不如烂笔头。

    310 引用 • 794 回帖
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    368 引用 • 1846 回帖
  • OnlyOffice
    4 引用 • 22 关注
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 3 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    173 引用 • 518 回帖
  • RYMCU

    RYMCU 致力于打造一个即严谨又活泼、专业又不失有趣,为数百万人服务的开源嵌入式知识学习交流平台。

    4 引用 • 6 回帖 • 56 关注
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    21 引用 • 245 回帖 • 228 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 20 关注
  • 导航

    各种网址链接、内容导航。

    44 引用 • 177 回帖
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 564 关注
  • OpenStack

    OpenStack 是一个云操作系统,通过数据中心可控制大型的计算、存储、网络等资源池。所有的管理通过前端界面管理员就可以完成,同样也可以通过 Web 接口让最终用户部署资源。

    10 引用 • 3 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖
  • 强迫症

    强迫症(OCD)属于焦虑障碍的一种类型,是一组以强迫思维和强迫行为为主要临床表现的神经精神疾病,其特点为有意识的强迫和反强迫并存,一些毫无意义、甚至违背自己意愿的想法或冲动反反复复侵入患者的日常生活。

    15 引用 • 161 回帖
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 1 关注