zoukankan      html  css  js  c++  java
  • 纯js实现省市级联效果

    我们都知道一般有注册的时候会让用户填入省市啊地区什么的,然后我就想使用纯js制作一个省市级联的效果,只是用于学习以及回顾温习用,首先看下效果图,界面很丑啊,不要嫌弃!

    首先还是先看下我的项目目录吧

    很清晰明了,什么样的文件放入什么样的文件夹中,劝大家还是养成分文件夹存放的习惯,这样看的条理清晰也方便我们管理,以及维护等等

    可以看到,我将实现省市级联的js文件放入了js文件夹中,将得到的省市的json数据放入json文件夹中,界面就不用说了吧

    这里先放上我们的界面代码

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%
    String path = request.getContextPath();
    String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/";
    %>
    <!DOCTYPE>
    <html>
      <head>
        <base href="<%=basePath%>">
        <title></title>
      </head>
      <style>
      	body{
      		margin:0px;
      		padding:0px;
      	}
    	.div_swf{
    			 100%;
    			height: 150px;
    			border: 1px  solid black;
    	}
      </style>
      <!-- 引入外部json文件,记得下载josn文件的时候,要重新使用记事本打开一次,然后另存为的时候设置下编码格式为utf-8,这样就避免了乱码 -->
      <script type="text/javascript" src="../json/province_city.json"></script>
      <!-- 引入外部设置省市级联的js文件,新建一个js文件的时候会出现乱码,但是经过使用记事本打开后另存为的时候设置编码格式即可 -->
      <script type="text/javascript" src="../js/ss.js"></script>
      <body onload="onload()">
    	<div style="text-align: center; 250px;margin-top:10px;">
    		<font>省市级联效果</font><br><br>
    		<!-- 这里是选择省份 -->
    		<select id ="Province" onchange ="changeCity()">
    			<option >请选择省份</option>
    		</select>
    		<!-- 这里是选择市 -->
    		<select id ="city">
    			<option >请选择城市</option>
    		</select>
    	</div>
      </body>
    </html>
    

    可以看到我界面代码中根本就没有出现js代码,是因为我把js代码让入了外部js文件夹里面,为什么这样放,试想一下,如果我们把js代码都写到界面里面是不是会非常的混杂,而且很多,不方便阅读以及管理,这样做只是为了让我们的代码更加简洁易懂,方便管理

    好啦,废话就不说了,接下来就开始实现我们的省市级联了

     

    首先的第一步肯定是要先准备好省市的数据,我就随便在网上找了下,然后经过自己的修改后将它保存为了一份json文件,这里给你们吧,直接赋值到文本里面然后改后缀即可

    var json = [
        {
            "北京市": [
                "西城",
                "东城",
                "崇文",
                "宣武",
                "朝阳",
                "海淀",
                "丰台",
                "石景山",
                "门头沟",
                "房山",
                "通州",
                "顺义",
                "大兴",
                "昌平",
                "平谷",
                "怀柔",
                "密云",
                "延庆"
            ],
            "name": "北京市"
        },
        {
            "天津市": [
                "青羊",
                "河东",
                "河西",
                "南开",
                "河北",
                "红桥",
                "塘沽",
                "汉沽",
                "大港",
                "东丽",
                "西青",
                "北辰",
                "津南",
                "武清",
                "宝坻",
                "静海",
                "宁河",
                "蓟县",
                "开发区"
            ],
            "name": "天津市"
        },
        {
            "河北省": [
                "石家庄",
                "秦皇岛",
                "廊坊",
                "保定",
                "邯郸",
                "唐山",
                "邢台",
                "衡水",
                "张家口",
                "承德",
                "沧州",
                "衡水"
            ],
            "name": "河北省"
        },
        {
            "山西省": [
                "太原",
                "大同",
                "长治",
                "晋中",
                "阳泉",
                "朔州",
                "运城",
                "临汾"
            ],
            "name": "山西省"
        },
        {
            "内蒙古自治区": [
                "呼和浩特",
                "赤峰",
                "通辽",
                "锡林郭勒",
                "兴安"
            ],
            "name": "内蒙古自治区"
        },
        {
            "辽宁省": [
                "大连",
                "沈阳",
                "鞍山",
                "抚顺",
                "营口",
                "锦州",
                "丹东",
                "朝阳",
                "辽阳",
                "阜新",
                "铁岭",
                "盘锦",
                "本溪",
                "葫芦岛"
            ],
            "name": "辽宁省"
        },
        {
            "吉林省": [
                "长春",
                "吉林",
                "四平",
                "辽源",
                "通化",
                "延吉",
                "白城",
                "辽源",
                "松原",
                "临江",
                "珲春"
            ],
            "name": "吉林省"
        },
        {
            "黑龙江省": [
                "哈尔滨",
                "齐齐哈尔",
                "大庆",
                "牡丹江",
                "鹤岗",
                "佳木斯",
                "绥化"
            ],
            "name": "黑龙江省"
        },
        {
            "上海市": [
                "浦东",
                "杨浦",
                "徐汇",
                "静安",
                "卢湾",
                "黄浦",
                "普陀",
                "闸北",
                "虹口",
                "长宁",
                "宝山",
                "闵行",
                "嘉定",
                "金山",
                "松江",
                "青浦",
                "崇明",
                "奉贤",
                "南汇"
            ],
            "name": "上海市"
        },
        {
            "江苏省": [
                "南京",
                "苏州",
                "无锡",
                "常州",
                "扬州",
                "徐州",
                "南通",
                "镇江",
                "泰州",
                "淮安",
                "连云港",
                "宿迁",
                "盐城",
                "淮阴",
                "沐阳",
                "张家港"
            ],
            "name": "江苏省"
        },
        {
            "浙江省": [
                "杭州",
                "金华",
                "宁波",
                "温州",
                "嘉兴",
                "绍兴",
                "丽水",
                "湖州",
                "台州",
                "舟山",
                "衢州"
            ],
            "name": "浙江省"
        },
        {
            "安徽省": [
                "合肥",
                "马鞍山",
                "蚌埠",
                "黄山",
                "芜湖",
                "淮南",
                "铜陵",
                "阜阳",
                "宣城",
                "安庆"
            ],
            "name": "安徽省"
        },
        {
            "福建省": [
                "福州",
                "厦门",
                "泉州",
                "漳州",
                "南平",
                "龙岩",
                "莆田",
                "三明",
                "宁德"
            ],
            "name": "福建省"
        },
        {
            "江西省": [
                "南昌",
                "景德镇",
                "上饶",
                "萍乡",
                "九江",
                "吉安",
                "宜春",
                "鹰潭",
                "新余",
                "赣州"
            ],
            "name": "江西省"
        },
        {
            "山东省": [
                "青岛",
                "济南",
                "淄博",
                "烟台",
                "泰安",
                "临沂",
                "日照",
                "德州",
                "威海",
                "东营",
                "荷泽",
                "济宁",
                "潍坊",
                "枣庄",
                "聊城"
            ],
            "name": "山东省"
        },
        {
            "河南省": [
                "郑州",
                "洛阳",
                "开封",
                "平顶山",
                "濮阳",
                "安阳",
                "许昌",
                "南阳",
                "信阳",
                "周口",
                "新乡",
                "焦作",
                "三门峡",
                "商丘"
            ],
            "name": "河南省"
        },
        {
            "湖北省": [
                "武汉",
                "襄樊",
                "孝感",
                "十堰",
                "荆州",
                "黄石",
                "宜昌",
                "黄冈",
                "恩施",
                "鄂州",
                "江汉",
                "随枣",
                "荆沙",
                "咸宁"
            ],
            "name": "湖北省"
        },
        {
            "湖南省": [
                "长沙",
                "湘潭",
                "岳阳",
                "株洲",
                "怀化",
                "永州",
                "益阳",
                "张家界",
                "常德",
                "衡阳",
                "湘西",
                "邵阳",
                "娄底",
                "郴州"
            ],
            "name": "湖南省"
        },
        {
            "广东省": [
                "广州",
                "深圳",
                "东莞",
                "佛山",
                "珠海",
                "汕头",
                "韶关",
                "江门",
                "梅州",
                "揭阳",
                "中山",
                "河源",
                "惠州",
                "茂名",
                "湛江",
                "阳江",
                "潮州",
                "云浮",
                "汕尾",
                "潮阳",
                "肇庆",
                "顺德",
                "清远"
            ],
            "name": "广东省"
        },
        {
            "广西壮族自治区": [
                "南宁",
                "桂林",
                "柳州",
                "梧州",
                "来宾",
                "贵港",
                "玉林",
                "贺州"
            ],
            "name": "广西壮族自治区"
        },
        {
            "海南省": [
                "海口",
                "三亚"
            ],
            "name": "海南省"
        },
        {
            "重庆市": [
                "渝中",
                "大渡口",
                "江北",
                "沙坪坝",
                "九龙坡",
                "南岸",
                "北碚",
                "万盛",
                "双桥",
                "渝北",
                "巴南",
                "万州",
                "涪陵",
                "黔江",
                "长寿"
            ],
            "name": "重庆市"
        },
        {
            "四川省": [
                "成都",
                "达州",
                "南充",
                "乐山",
                "绵阳",
                "德阳",
                "内江",
                "遂宁",
                "宜宾",
                "巴中",
                "自贡",
                "康定",
                "攀枝花"
            ],
            "name": "四川省"
        },
        {
            "贵州省": [
                "贵阳",
                "遵义",
                "安顺",
                "黔西南",
                "都匀"
            ],
            "name": "贵州省"
        },
        {
            "云南省": [
                "昆明",
                "丽江",
                "昭通",
                "玉溪",
                "临沧",
                "文山",
                "红河",
                "楚雄",
                "大理"
            ],
            "name": "云南省"
        },
        {
            "西藏自治区": [
                "拉萨",
                "林芝",
                "日喀则",
                "昌都"
            ],
            "name": "西藏自治区"
        },
        {
            "陕西省": [
                "西安",
                "咸阳",
                "延安",
                "汉中",
                "榆林",
                "商南",
                "略阳",
                "宜君",
                "麟游",
                "白河"
            ],
            "name": "陕西省"
        },
        {
            "甘肃省": [
                "兰州",
                "金昌",
                "天水",
                "武威",
                "张掖",
                "平凉",
                "酒泉"
            ],
            "name": "甘肃省"
        },
        {
            "青海省": [
                "黄南",
                "海南",
                "西宁",
                "海东",
                "海西",
                "海北",
                "果洛",
                "玉树"
            ],
            "name": "青海省"
        },
        {
            "宁夏回族自治区": [
                "银川",
                "吴忠"
            ],
            "name": "宁夏回族自治区"
        },
        {
            "新疆维吾尔自治区": [
                "乌鲁木齐",
                "哈密",
                "喀什",
                "巴音郭楞",
                "昌吉",
                "伊犁",
                "阿勒泰",
                "克拉玛依",
                "博尔塔拉"
            ],
            "name": "新疆维吾尔自治区"
        },
        {
            "香港特别行政区": [
                "中西区",
                "湾仔区",
                "东区",
                "南区",
                "九龙-油尖旺区",
                "九龙-深水埗区",
                "九龙-九龙城区",
                "九龙-黄大仙区",
                "九龙-观塘区",
                "新界-北区",
                "新界-大埔区",
                "新界-沙田区",
                "新界-西贡区",
                "新界-荃湾区",
                "新界-屯门区",
                "新界-元朗区",
                "新界-葵青区",
                "新界-离岛区"
            ],
            "name": "香港特别行政区"
        },
        {
            "澳门特别行政区": [
                "花地玛堂区",
                "圣安多尼堂区",
                "大堂区",
                "望德堂区",
                "风顺堂区",
                "嘉模堂区",
                "圣方济各堂区",
                "路氹城"
            ],
            "name": "澳门特别行政区"
        }
    ]
    View Code

     

     说明下为什么我开头会加上 var json = ,这是因为这个json文件是一个独立的外部文件,而我们的js脚本想要访问到里面的内容的时候就要做两步,先就像我这样 使用var json = 然后在页面中进行引入这个json文件

    <script type="text/javascript" src="../json/province_city.json"></script>

    这样我们的js就可以获取到json文件里面的内容了,当然我们的js文件肯定也是要引入的,这里就不再说了

    说个重要的吧,当我们引入这个json文件的还是可能会出现乱码是因为默认的编码格式是ANSI格式的,如果里面还有中文的话就会出现乱码,那么怎么解决呢?其实很简单,把这个js文件使用记事本打开后进行另存为,在另存为的时候有个编码,将它修改为utf-8即可

     

    ok,我们的数据准备个工作做好啦!接下来就是开始实现我们的功能了

    首先在界面上写上我们需要的下拉框组件

    <div style="text-align: center; 250px;margin-top:10px;">
    		<font>省市级联效果</font><br><br>
    		<!-- 这里是选择省份 -->
    		<select id ="Province" onchange ="changeCity()">
    			<option >请选择省份</option>
    		</select>
    		<!-- 这里是选择市 -->
    		<select id ="city">
    			<option >请选择城市</option>
    		</select>
    </div>
    

    当然这样是没有实现省市级联的,是因为我把实现代码也就是js代码放入了外部js文件中了,直接使用即可,写贴上我们的代码

    //这个方法用来给省份的select赋值
    function onload(){
        //获取json格式之后转化为数组
        var json_array = eval(json);
        var Province = document.getElementById("Province");
        for(var i = 0;i<json_array.length;i++){
            var json_p = json_array[i].name;
            Province.add(new Option(json_p,json_p), null);
        }
    };
     //这个方法就是实现省市级联的核心方法,也是用来给市的select赋值
    function changeCity() {
         var Province = document.getElementById("Province");
         var Provincevalue = Province.options[Province.selectedIndex].value;
         var city = document.getElementById("city");
         var optinsValue;
         //获取json格式之后转化为数组
        var json_array = eval(json);
        //获取当前选中的省份Province.value;
        city.options.length = 0; //清空城市
        switch(Provincevalue){
            case "北京市":
                    optinsValue = json_array[0].北京市;
                break;
            case "天津市":
                    optinsValue = json_array[1].天津市;
                break;
            case "河北省":
                    optinsValue = json_array[2].河北省;
                break;
            case "山西省":
                    optinsValue = json_array[3].山西省;
                break;
            case "内蒙古自治区":
                    optinsValue = json_array[4].内蒙古自治区;
                break;
            case "辽宁省":
                    optinsValue = json_array[5].辽宁省;
                break;
            case "吉林省":
                    optinsValue = json_array[6].吉林省;
                break;
            case "黑龙江省":
                    optinsValue = json_array[7].黑龙江省;
                break;
            case "上海市":
                    optinsValue = json_array[8].上海市;
                break;
            case "江苏省":
                    optinsValue = json_array[9].江苏省;
                break;
            case "浙江省":
                    optinsValue = json_array[10].浙江省;
                break;
            case "安徽省":
                    optinsValue = json_array[11].安徽省;
                break;
            case "福建省":
                    optinsValue = json_array[12].福建省;
                break;
            case "江西省":
                    optinsValue = json_array[13].江西省;
                break;
            case "山东省":
                    optinsValue = json_array[14].山东省;
                break;
            case "河南省":
                    optinsValue = json_array[15].河南省;
                break;
            case "湖北省":
                    optinsValue = json_array[16].湖北省;
                break;
            case "湖南省":
                    optinsValue = json_array[17].湖南省;
                break;
            case "广东省":
                    optinsValue = json_array[18].广东省;
                break;
            case "广西壮族自治区":
                    optinsValue = json_array[19].广西壮族自治区;
                break;
            case "海南省":
                    optinsValue = json_array[20].海南省;
                break;
            case "重庆市":
                    optinsValue = json_array[21].重庆市;
                break;
            case "四川省":
                    optinsValue = json_array[22].四川省;
                break;
            case "贵州省":
                    optinsValue = json_array[23].贵州省;
                break;
            case "云南省":
                    optinsValue = json_array[24].云南省;
                break;
            case "西藏自治区":
                    optinsValue = json_array[25].西藏自治区;
                break;
            case "陕西省":
                    optinsValue = json_array[26].陕西省;
                break;
            case "甘肃省":
                    optinsValue = json_array[27].甘肃省;
                break;
            case "青海省":
                    optinsValue = json_array[28].青海省;
                break;
            case "宁夏回族自治区":
                    optinsValue = json_array[29].宁夏回族自治区;
                break;
            case "新疆维吾尔自治区":
                    optinsValue = json_array[30].新疆维吾尔自治区;
                break;
            case "香港特别行政区":
                    optinsValue = json_array[31].香港特别行政区;
                break;
            case "澳门特别行政区":
                    optinsValue = json_array[32].澳门特别行政区;
                break;
        }
        trim(optinsValue,city);
    };
    //转化为数据的形式为市select赋值,需要数据,以及select这个标签
    function trim(obj,label){
        for(var i = 0;i<obj.length;i++){
            label.add(new Option(obj[i],obj[i]), null);
        }
    };
    View Code

    其实这代码也没什么可讲的,因为不怎么难,很容易看懂,我就挑重要的说下

    for(var i = 0;i<json_array.length;i++){
    		var json_p = json_array[i].name;
    		Province.add(new Option(json_p,json_p), null);
    }

    这一行代码主要就是获取我们json文件里面所有的省份、直辖市啊、自治区的名称然后通过一个for循环将值赋给我们的select标签

    主要就是通过了Province.add(new Option(json_p,json_p), null);这个方法将我们的值赋给我们的select标签,因为我们都知道select的子节点就是option

    所以这里就直接new option()然后讲我们的值赋上,这里只是我们省份的代码

    再看下我们显示市的代码,

    //这个方法就是实现省市级联的核心方法,也是用来给市的select赋值
    function changeCity() {
         var Province = document.getElementById("Province");
         var Provincevalue = Province.options[Province.selectedIndex].value;
         var city = document.getElementById("city");
         var optinsValue;
         //获取json格式之后转化为数组
        var json_array = eval(json);
        //获取当前选中的省份Province.value;
        city.options.length = 0; //清空城市
        switch(Provincevalue){
            case "北京市":
                    optinsValue = json_array[0].北京市;
                break;
            case "天津市":
                    optinsValue = json_array[1].天津市;
                break;
            case "河北省":
                    optinsValue = json_array[2].河北省;
                break;
            case "山西省":
                    optinsValue = json_array[3].山西省;
                break;
            case "内蒙古自治区":
                    optinsValue = json_array[4].内蒙古自治区;
                break;
            case "辽宁省":
                    optinsValue = json_array[5].辽宁省;
                break;
            case "吉林省":
                    optinsValue = json_array[6].吉林省;
                break;
            case "黑龙江省":
                    optinsValue = json_array[7].黑龙江省;
                break;
            case "上海市":
                    optinsValue = json_array[8].上海市;
                break;
            case "江苏省":
                    optinsValue = json_array[9].江苏省;
                break;
            case "浙江省":
                    optinsValue = json_array[10].浙江省;
                break;
            case "安徽省":
                    optinsValue = json_array[11].安徽省;
                break;
            case "福建省":
                    optinsValue = json_array[12].福建省;
                break;
            case "江西省":
                    optinsValue = json_array[13].江西省;
                break;
            case "山东省":
                    optinsValue = json_array[14].山东省;
                break;
            case "河南省":
                    optinsValue = json_array[15].河南省;
                break;
            case "湖北省":
                    optinsValue = json_array[16].湖北省;
                break;
            case "湖南省":
                    optinsValue = json_array[17].湖南省;
                break;
            case "广东省":
                    optinsValue = json_array[18].广东省;
                break;
            case "广西壮族自治区":
                    optinsValue = json_array[19].广西壮族自治区;
                break;
            case "海南省":
                    optinsValue = json_array[20].海南省;
                break;
            case "重庆市":
                    optinsValue = json_array[21].重庆市;
                break;
            case "四川省":
                    optinsValue = json_array[22].四川省;
                break;
            case "贵州省":
                    optinsValue = json_array[23].贵州省;
                break;
            case "云南省":
                    optinsValue = json_array[24].云南省;
                break;
            case "西藏自治区":
                    optinsValue = json_array[25].西藏自治区;
                break;
            case "陕西省":
                    optinsValue = json_array[26].陕西省;
                break;
            case "甘肃省":
                    optinsValue = json_array[27].甘肃省;
                break;
            case "青海省":
                    optinsValue = json_array[28].青海省;
                break;
            case "宁夏回族自治区":
                    optinsValue = json_array[29].宁夏回族自治区;
                break;
            case "新疆维吾尔自治区":
                    optinsValue = json_array[30].新疆维吾尔自治区;
                break;
            case "香港特别行政区":
                    optinsValue = json_array[31].香港特别行政区;
                break;
            case "澳门特别行政区":
                    optinsValue = json_array[32].澳门特别行政区;
                break;
        }
        trim(optinsValue,city);
    };
    View Code

    很多啊,都是一些case什么的,之前本来是不想写这么多的case的,想的是直接获取省份select的值然后在.出来的,可是出现了一个问题就是

    .的时候js总是会把我们获取的到的值当成了key,所以获取市的时候就是一直弹出undefined,所以只能采取这样的办法,大家有什么办法可以向我反馈,感谢

    为什么我在方法最后面会有一个trim方法,是因为我看到json市的数据的时候是使用,进行分割的,所以我就加了一个分割的方法,同时也把赋值放入了这个方法中

    //转化为数据的形式为市select赋值,传入数据,以及select这个标签
    function trim(obj,label){
    	for(var i = 0;i<obj.length;i++){
    		label.add(new Option(obj[i],obj[i]), null);
    	}
    };
    

      

    至此我们的整个效果就实现了,不是很难,在新建js文件的时候也会出现乱码问题,解决的办法上面已经介绍了,就不在论述了,赋值市的时候如果大家有什么好的办法,欢迎大家积极反馈

  • 相关阅读:
    open jdk卸载
    “玲珑杯”ACM比赛 Round #18---图论你先敲完模板(DP+思维)
    “玲珑杯”ACM比赛 Round #18--最后你还是AK了(搜索+思维)
    hdu 5116--Everlasting L(计数DP)
    HDU 5113--Black And White(搜索+剪枝)
    hdu 5573---Binary Tree(构造)
    HDU 5517---Triple(二维树状数组)
    hdu 5975---Aninteresting game(树状数组)
    hdu 5972---Regular Number(字符串匹配)
    HDU 4570---Multi-bit Trie(区间DP)
  • 原文地址:https://www.cnblogs.com/luhan/p/5981805.html
Copyright © 2011-2022 走看看