<html>
<head>
<META charset="utf8">
<script type="text/javascript" src="http://code.jquery.com/jquery.js"></script>
<script>
(function($) {
    $.fn.areaSelInit = function() {
        return $(this).html("<option>请选择</option>");
    };
    $.area = function(data,sel) {
        /** 初始化 **/
        $("#province").areaSelInit();
        $("#city").areaSelInit();
        $("#county").areaSelInit();
        /** 选中特定值 **/
        $.each(data, function(p,x) {
            var s1 = '';
            if(undefined!=sel){
                s1 = (p==sel[0]) ? 'selected' : '';
            }
            $("#province").append("<option "+s1+">" + p + "</option>"); // 省

            if(undefined!=sel){
                if ($("#province option:selected").text()==p) {
                    $.each(x,function(c,cx){
                        var s2 = '';
                        s2 = (c==sel[1]) ? 'selected' : '';
                        $("#city").append("<option "+s2+">" + c + "</option>"); // 市

                        if ($("#city option:selected").text()==c) {
                            $.each(cx.split(","),function(){
                                var s3 = '';
                                s3 = (this==sel[2]) ? 'selected' : '';
                                $("#county").append("<option "+s3+">" + this + "</option>"); // 区
                            });
                        }

                    });
                }
            }
        });
        /** onchange事件 **/
        $("#province").change(function() {
            $("#city").areaSelInit();
            $("#county").areaSelInit();
            $.each(data, function(p, x) {
                if ($("#province option:selected").text() == p) {
                    $.each(x, function(c, cx) {
                        $("#city").append("<option>" + c + "</option>"); // 市
                    });

                    $("#city").bind("change", function() {
                        $("#county").areaSelInit();
                        $.each(x, function(c, cx) {
                            if ($("#city option:selected").text() == c) {
                                $.each(cx.split(","), function() {
                                    $("#county").append("<option>" + this + "</option>"); // 区
                                });
                            }
                        });
                    });
                }
            });
        });
    };
})(jQuery);
$(function() {
    var data = {北京: {北京: "东城,西城,海淀,宣武,丰台"
            },
            江苏: {南京: "江宁,六合,下关,浦口",
                无锡: "北塘,滨湖,江阴,宜兴"
            },
            广东: {广州: "越秀区,东山区,海珠区,荔湾区,天河区,白云区,黄埔区,芳村区,番禺区,花都区,增城市,从化市",
                揭阳: "榕城区,揭东县,揭西县,普宁市"
            }
        };
    var sel = ['广东','揭阳']; // 或: var sel = [];
    $.area(data,sel);
});
</script>
</head>
<body>
    <select id="province"><option>请选择</option></select>
    <select id="city"><option>请选择</option></select>
    <select id="county"><option>请选择</option></select>
</body>
</html>

  

;

js城市联动选择器的更多相关文章

  1. 全国三级城市联动 js版

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. JS中简单的二级城市联动

    代码奉上: <!DOCTYPE html><html><head>    <meta charset="UTF-8">    < ...

  3. [js开源组件开发]js手机联动选择日期 开源git

    js手机联动选择日期 这里在前面的<js手机联动选择地区>的基础上,改造数据源之后形成的一个日期的选择器,当然你可以使用之前的PC上模式的<日期控件>,它同时也支持手机端,ht ...

  4. [JS]以下是JS省市联动菜单代码

    以下是JS省市联动菜单代码: 代码一: <html> <head> <title></title> <script language=" ...

  5. JQUERY省、市、县城市联动选择

    JQUERY 插件开发——CITYLINKAGE(省.市.县城市联动选择) 第一部分:背景   开发源于需求,本次城市联动选择插件算是我写插件的一个特例吧,不是我目前工作需要些的,算是兴趣驱使吧.之前 ...

  6. JS省市区联动效果

    省市区联动下拉效果在WEB中应用非常广泛,尤其在电商网站最为常见.一般使用Ajax实现无刷新下拉联动.利用jQuery,通过读取JSON数据,实现无刷新动态下拉省市二(三)级联动效果. 首先我们可以看 ...

  7. js 多级联动(省、市、区)

      js 多级联动(省.市.区) CreateTime--2018年4月9日17:10:38 Author:Marydon 方式一: 数据从数据库获取,ajax实现局部刷新 方式二: 数据从json文 ...

  8. Jquery 插件开发——citylinkage(省、市、县城市联动选择)

    第一部分:背景  开发源于需求,本次城市联动选择插件算是我写插件的一个特例吧,不是我目前工作需要些的,算是兴趣驱使吧.之前呢,一直想写这个插件,然后错过了一个写这个插件的机会(这个得回顾到很久以前了. ...

  9. 省市区js三级联动(原创)

    看了一些网上的js三级联动,但感觉不是缺这,就是少那,决定亲自操刀写了一个,现记录如下,以备后用! <!DOCTYPE html> <html> <head> &l ...

随机推荐

  1. CountDownLatch模拟高并发测试代码

    直接上代码进行验证吧 /** * 通过countdownlatch的机制,来实现并发运行 * 模拟200个并发测试 * @author ll * @date 2018年4月18日 下午3:55:59 ...

  2. solrCloud分布式检索流程

    FROM: http://blog.csdn.net/duck_genuine/article/details/17014991 好久没写solr的文章了,刚好需要在公司作个分享,先总结一些先. 引用 ...

  3. hdu 4512 吉哥系列故事——完美队形I(最长公共上升自序加强版)

    首先要去学习最长公共上升子序列LCIS.然后是对n*n效率的算法进行优化,这里要注意的是能够求出来的序列中间能够有一个最高的.刚開始将输入的数组进行逆置,写下来发现这可能存在问题. 只是详细是什么也没 ...

  4. 使用SQLite存储数据

    一.SQLiteAndroid 为了让我们能够更加方便地管理数据库, 专门提供了一个SQLiteOpenHelper 帮助类,借助这个类就可以非常简单地对数据库进行创建和升级. 1.SQLiteOpe ...

  5. windows新建或者重命名文件及目录必须手动刷新才干显示出来问题解决方法

     首先推断注冊表中HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\Update\UpdateMode值是否为0,该值若为1表示手工刷新, 该 ...

  6. redhat 用yum安装的apache、mysql一般默认安装在哪个目录下?

    使用yum安装成功后,使用rpm -qa | grep httpd和rpm -qa | grep mysql查看是否安装成功然后使用rpm -ql httpd和rpm -ql mysql查看安装文件都 ...

  7. KingdeeK3-修改单据邮件发送的自定义字段

    只需要执行类似下面语句即可: update ICTemplateentry set FVisForBillType = 63,flookupcls=6 where fid ='P01' and fhe ...

  8. 深入理解Tomcat系列之五:Context容器和Wrapper容器

    前言 Context容器是一个Web项目的代表,主要管理Servlet实例,在Tomcat中Servlet实例是以Wrapper出现的.如今问题是怎样才干通过Context容器找到详细的Servlet ...

  9. Verilog 浮点数运算模块

    算法中常常会到浮点数运算,而浮点数的处理常常是Verilog初学中常常遇到的问题.以下将就一个简单的例子说明Verilog中浮点数运算处理. 在JPEG图像压缩时遇到色彩空间变换的问题,将YCbCr转 ...

  10. 连接redis失败,关闭防火墙即可

    因为linux上有防火墙,我用redis desktop manager 测试所以始终连接不上, 关闭防火墙: systemctl stop firewalld.service #停止firewall ...