JavaScript实现省市区的三级联动
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>
调试

备注
- .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实现省市区的三级联动的更多相关文章
- 省市区(县)三级联动代码(js 数据源)
ylbtech-JavaScript-Utility:省市区(县)三级联动代码(js 数据源) 省市区(县)三级联动代码(js 数据源) 1.A,源代码(Source Code)返回顶部 1.A.1, ...
- JQuery实现省市区的三级联动
JQuery实现省市区的三级联动 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "h ...
- js之省市区(县)三级联动效果
省市区(县)三级联动效果,是我们软件开发比较常用的,特别是对一些crm,erp之类,当然也包括其他的后台管理系统,基本都涉及到,今天贴出这个常用的,方便个人复用和大家使用 <!DOCTYPE h ...
- 中国省市区地址三级联动jQuery插件 案例下载
中国省市区地址三级联动jQuery插件 案例下载 distpicker 是一款可以实现中国省市区地址三级联动jQuery插件.它使用简单,简单设置即可完成中国省市区地址联动效果. 安装 可以通过npm ...
- 中国省市区地址三级联动插件---jQuery Distpicker
插件描述:distpicker是一款可以实现中国省市区地址三级联动jQuery插件.它使用简单,简单设置即可完成中国省市区地址联动效果. [官网]https://fengyuanchen.github ...
- 省市区js三级联动(原创)
看了一些网上的js三级联动,但感觉不是缺这,就是少那,决定亲自操刀写了一个,现记录如下,以备后用! <!DOCTYPE html> <html> <head> &l ...
- 转: javascript实现全国城市三级联动菜单代码
<html> <head> <title>js全国城市三级联动菜单代码_B5教程网</title> <meta http-equiv=" ...
- 原生JavaScript的省市县三级联动
三级联动是我们写表单时必不可少的,比如在写收货地址时,就用到他了,最近在看原生JavaScript,从基础写起,待完善,以后再写个jquery版的. <!DOCTYPE html> < ...
- 用php和ajax写一个省市区的三级联动,实现地区的下拉选择
要实现这个页面的三级联动,我们需要建立三个php文件,第一个php文件我们导入jQuery文件,里面嵌入JavaScript:第二个php文件我们做一个php的处理页面,里面引入我们封装好的数据库类文 ...
随机推荐
- C# 最齐全的上传图片方法
方法里包括了图片大小限制.图片尺寸.文件内容等等的判断... 该案例是mvc下的demo,支持单张图片上传. public ActionResult Upload() { string imgurl ...
- 一个自己实现的js表单验证框架。
经常要做一些表单验证的操作,每次都是用现成的框架,比如jquery,bootstrap等的验证插件,虽然也很强大,也很好用,可就是用起来需要引入许多js库,还有里面功能太多,感觉不太符合自己的需求.最 ...
- 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 ...
- day12_雷神_线程总结
#线程 1. 多线程理论 0.进程只是一个资源单位,用来隔离资源,从执行角度是主线程. 1.多个线程共享一个进程的数据资源: 2.线程开销小: 2. 开线程的两种方式 0. 站在资源的角度,主进程:执 ...
- 背水一战 Windows 10 (87) - 文件系统: 获取文件的属性, 修改文件的属性, 获取文件的缩略图
[源码下载] 背水一战 Windows 10 (87) - 文件系统: 获取文件的属性, 修改文件的属性, 获取文件的缩略图 作者:webabcd 介绍背水一战 Windows 10 之 文件系统 获 ...
- 三种定义bean的方式
方法一:基于XML的bean定义(需要提供setter方法) 1.首先编写student.java和teacher.java两个类 Student.java: public class Student ...
- Ubuntu 16.04虚拟机调整窗口大小自适应Windows 7
Windows 7上Ubuntu 16.04虚拟机安装成功后,默认的虚拟机窗口比较小,需要适当调整,才能把虚拟机的屏幕放大, 适合使用,以下介绍调整方法. 安装VMware Tools 启动虚拟机, ...
- cad2008 参照面板 在位编辑后无法使用
有时候在位编辑之后,保存在位编辑了,可是参照面板无法动了,这个时候只要保存一下,然后ctrl+z,就可以解决了..蛮神奇的,我还没想到如何用代码去搞定它..
- 【转载】MyBatis JdbcType 与Oracle、MySql数据类型对应关系详解
[原文链接]:MyBatis JdbcType 与Oracle.MySql数据类型对应关系详解 1. Mybatis JdbcType与Oracle.MySql数据类型对应列表 2. Mybatis ...
- Linux下解压.tar.xz格式文件的方法
前言 对于xz这个压缩相信很多人陌生,但xz是绝大数linux默认就带的一个压缩工具,xz格式比7z还要小. 今天在下载Node.js源码包的时候遇到的这种压缩格式.查了一下资料,这里进行一下记录,分 ...