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. chrome内核浏览器缓存资源找回方法

    曾几何时,用chrome浏览器看了某个图片,网页,视频等,当时没保存,后来再怎么找都找不到了,chrome还把缓存加密了,不能像ie那样找回,这世上有买后悔药的吗?还真有! 搜索chromeCache ...

  2. MSSQL - 视图操作

    查询语句(包含使用Where子句): string sql = @"SELECT TableName, TablePosition,TableSate, TabelType,OpenTime ...

  3. Coursera台大机器学习基础课程1

    Coursera台大机器学习基础课程学习笔记 -- 1 最近在跟台大的这个课程,觉得不错,想把学习笔记发出来跟大家分享下,有错误希望大家指正. 一 机器学习是什么? 感觉和 Tom M. Mitche ...

  4. 【2017-04--28】Winform中ListView控件

    ListView 1.先设置列,设置视图属性选择Details. 添加列,修改列名. 2.编辑项(添加行数据) 添加一个ListViewItem对象,该对象的Text对应着是第一列的数据, 在该对象的 ...

  5. 如何在自己的网页上插入一个超链接,发起临时qq会话

    1.先开通临时会话功能 打开网页http://shang.qq.com/v3/index.html

  6. 精通CSS+DIV网页样式与布局--滤镜的使用

    在上篇博客中,小编主要简单的介绍了使用CSS,如何制作实用菜单,今天我们继续来总结有关CSS的基础知识,今天小编主要简单的来介绍一下CSS中关于滤镜的使用,首先,小编先来简单的介绍一下滤镜,我们这次来 ...

  7. Comparison of Static Code Analysis Tools for Java

    http://www.sw-engineering-candies.com/blog-1/comparison-of-findbugs-pmd-and-checkstyle https://stack ...

  8. UVa 1374 快速幂计算(dfs+IDA*)

    https://vjudge.net/problem/UVA-1374 题意:给出n,计算最少需要几次能让x成为x^n(x和已经生成的数相乘或相除). 思路:IDA*算法. 如果当前数组中最大的数乘以 ...

  9. 51nod-1103-抽屉原理

    1103 N的倍数  题目来源: Ural 1302 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题  收藏  关注 一个长度为N的数组A,从A中选出若干个数,使得 ...

  10. springboot使用过程中遇到的问题

    一.工具Intellij IDEA 二.基本问题 1.数据库语句 Caused by: java.lang.IllegalStateException: Cannot load driver clas ...