JavaScript实现省市区的三级联动

 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
 <html>
 <head>
 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
 <title>Insert title here</title>
 </head>
 <body>
 <div id="div1">
 </div>
 <script type="text/javascript">
     /* 创建省 */
     var provinceAr = ["湖北省","吉林省","湖南省"];
     var province = document.createElement("select");
     var province_one = document.createElement("option");
     var province_one_value = document.createTextNode("请选择省");
     province_one.appendChild(province_one_value);
     province.appendChild(province_one);
     document.getElementById("div1").appendChild(province);
     for(var i = 0; i < provinceAr.length; i++){
         province_one = document.createElement("option");
         province_one_value = document.createTextNode(provinceAr[i]);
         province_one.appendChild(province_one_value);
         province.appendChild(province_one);
     }
     /* 创建市 */
     var cityAr = [
                   ["襄阳市","武汉市","荆门市","恩施市"],
                   ["长春市","四平市","松原市"],
                   ["长沙市","岳阳市","益阳市"],
                   ];
     province.id = "proi";//给省添加id
     var city = document.createElement("select");
     document.getElementById("div1").appendChild(city);
     var city_one = document.createElement("option");
     var city_one_value = document.createTextNode("请选择市");
     city_one.appendChild(city_one_value);
     city.appendChild(city_one);
     city.id="cityI";//给市添加id
     /* 创建县 */
     var townAr = [
                 [
                      ["樊城区","襄州区","襄城区"],
                      ["江汉区","汉阳区","武昌区"],
                      ["京沙县","沙洋县","东宝区"],
                      ["舞阳坝街道","小渡船街道","六角亭街道"]
                  ],
                 [
                      ["南关区 ","朝阳区","宽城区"],
                      ["铁东区","铁西区","梨树县"],
                      ["宁江区","乾安县","长岭县"]
                  ],
                 [
                      ["长沙县 ","宁乡县","浏阳市"],
                      ["湘阴县","岳阳县","华容县"],
                      ["安化","桃江","南县"]
                  ]
                 ];
     var town = document.createElement("select");
     var town_one = document.createElement("option");
     var town_one_value = document.createTextNode("请选择县");
     town_one.appendChild(town_one_value);
     town.appendChild(town_one);
     document.getElementById("div1").appendChild(town);
     /* onchange拼写出错可能导致进程终止*/
     province.onchange = function(){
         var index = document.getElementById("proi").selectedIndex;//给select一个索引值
         city.innerHTML="";
         if(index==0){
             var city_one = document.createElement("option");
             var city_one_value = document.createTextNode("请选择市");
             city_one.appendChild(city_one_value);
             city.appendChild(city_one);
             town.innerHTML="";
             var town_one = document.createElement("option");
             var town_one_value = document.createTextNode("请选择县");
             town_one.appendChild(town_one_value);
             town.appendChild(town_one);
         }
         else
         {
             var cityValues = cityAr[index-1];
             var townValu = townAr[index-1];//townValu为一个二维数组
             console.log(cityValues);
             console.log(townValu);
             for(var i = 0; i < cityValues.length; i++){
                 var city_one = document.createElement("option");
                 var city_one_value = document.createTextNode(cityValues[i]);
                 city_one.appendChild(city_one_value);
                 city.appendChild(city_one);
             }
             var tor = townValu[0];
             console.log(tor);
             town.innerHTML="";
             for(var i = 0; i < tor.length; i++)
             {
             var town_one = document.createElement("option");
             var town_one_value = document.createTextNode(tor[i]);
             town_one.appendChild(town_one_value);
             town.appendChild(town_one);
             }
             city.onchange=function(){
                 var indexc = document.getElementById("cityI").selectedIndex;
                 var townVa = townValu[indexc];
                 town.innerHTML="";
                 console.log(townVa);
                 for(var i = 0; i < townVa.length; i++)
                 {
                 var town_one = document.createElement("option");
                 var town_one_value = document.createTextNode(townVa[i]);
                 town_one.appendChild(town_one_value);
                 town.appendChild(town_one);
                 }
             }
         }
     }
 </script>
 </body>
 </html>

调试

备注

  1. .innerHTML=" "的作用是为了清空select下的option样式,若不清空可能会导致select索引值发生改变

参考链接

http://www.w3school.com.cn/xmldom/met_document_createelement.asp(createElement() 方法)

http://www.w3school.com.cn/jsref/prop_option_index.asp(HTML DOM index属性)

JavaScript实现省市区的三级联动的更多相关文章

  1. 省市区(县)三级联动代码(js 数据源)

    ylbtech-JavaScript-Utility:省市区(县)三级联动代码(js 数据源) 省市区(县)三级联动代码(js 数据源) 1.A,源代码(Source Code)返回顶部 1.A.1, ...

  2. JQuery实现省市区的三级联动

    JQuery实现省市区的三级联动 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "h ...

  3. js之省市区(县)三级联动效果

    省市区(县)三级联动效果,是我们软件开发比较常用的,特别是对一些crm,erp之类,当然也包括其他的后台管理系统,基本都涉及到,今天贴出这个常用的,方便个人复用和大家使用 <!DOCTYPE h ...

  4. 中国省市区地址三级联动jQuery插件 案例下载

    中国省市区地址三级联动jQuery插件 案例下载 distpicker 是一款可以实现中国省市区地址三级联动jQuery插件.它使用简单,简单设置即可完成中国省市区地址联动效果. 安装 可以通过npm ...

  5. 中国省市区地址三级联动插件---jQuery Distpicker

    插件描述:distpicker是一款可以实现中国省市区地址三级联动jQuery插件.它使用简单,简单设置即可完成中国省市区地址联动效果. [官网]https://fengyuanchen.github ...

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

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

  7. 转: javascript实现全国城市三级联动菜单代码

    <html> <head> <title>js全国城市三级联动菜单代码_B5教程网</title> <meta http-equiv=" ...

  8. 原生JavaScript的省市县三级联动

    三级联动是我们写表单时必不可少的,比如在写收货地址时,就用到他了,最近在看原生JavaScript,从基础写起,待完善,以后再写个jquery版的. <!DOCTYPE html> < ...

  9. 用php和ajax写一个省市区的三级联动,实现地区的下拉选择

    要实现这个页面的三级联动,我们需要建立三个php文件,第一个php文件我们导入jQuery文件,里面嵌入JavaScript:第二个php文件我们做一个php的处理页面,里面引入我们封装好的数据库类文 ...

随机推荐

  1. C# 最齐全的上传图片方法

    方法里包括了图片大小限制.图片尺寸.文件内容等等的判断... 该案例是mvc下的demo,支持单张图片上传. public ActionResult Upload() { string imgurl ...

  2. 一个自己实现的js表单验证框架。

    经常要做一些表单验证的操作,每次都是用现成的框架,比如jquery,bootstrap等的验证插件,虽然也很强大,也很好用,可就是用起来需要引入许多js库,还有里面功能太多,感觉不太符合自己的需求.最 ...

  3. Do More With These Great Plugins for Windows Live Writer(old)

    This article is out of day,now we use open live wirter, but we don’t have so much works great plugin ...

  4. day12_雷神_线程总结

    #线程 1. 多线程理论 0.进程只是一个资源单位,用来隔离资源,从执行角度是主线程. 1.多个线程共享一个进程的数据资源: 2.线程开销小: 2. 开线程的两种方式 0. 站在资源的角度,主进程:执 ...

  5. 背水一战 Windows 10 (87) - 文件系统: 获取文件的属性, 修改文件的属性, 获取文件的缩略图

    [源码下载] 背水一战 Windows 10 (87) - 文件系统: 获取文件的属性, 修改文件的属性, 获取文件的缩略图 作者:webabcd 介绍背水一战 Windows 10 之 文件系统 获 ...

  6. 三种定义bean的方式

    方法一:基于XML的bean定义(需要提供setter方法) 1.首先编写student.java和teacher.java两个类 Student.java: public class Student ...

  7. Ubuntu 16.04虚拟机调整窗口大小自适应Windows 7

    Windows 7上Ubuntu 16.04虚拟机安装成功后,默认的虚拟机窗口比较小,需要适当调整,才能把虚拟机的屏幕放大, 适合使用,以下介绍调整方法. 安装VMware Tools  启动虚拟机, ...

  8. cad2008 参照面板 在位编辑后无法使用

    有时候在位编辑之后,保存在位编辑了,可是参照面板无法动了,这个时候只要保存一下,然后ctrl+z,就可以解决了..蛮神奇的,我还没想到如何用代码去搞定它..

  9. 【转载】MyBatis JdbcType 与Oracle、MySql数据类型对应关系详解

    [原文链接]:MyBatis JdbcType 与Oracle.MySql数据类型对应关系详解 1. Mybatis JdbcType与Oracle.MySql数据类型对应列表 2. Mybatis ...

  10. Linux下解压.tar.xz格式文件的方法

    前言 对于xz这个压缩相信很多人陌生,但xz是绝大数linux默认就带的一个压缩工具,xz格式比7z还要小. 今天在下载Node.js源码包的时候遇到的这种压缩格式.查了一下资料,这里进行一下记录,分 ...