原生JavaScript实现的简单省市县三级联动功能示例


Posted in Javascript onMay 27, 2017

本文实例讲述了原生JavaScript实现的简单省市县三级联动功能。分享给大家供大家参考,具体如下:

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

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>三级联动菜单</title>
<style>
select {
font-family: "萝莉体 第二版";
}
.hide {
display: none;
}
</style>
</head>
<body>
<div>
<select id="province">
<option>-请选择-</option>
</select>
<select id="city" class="hide">
<option>-请选择-</option>
</select>
<select id="area" class="hide">
<option>-请选择-</option>
</select>
</div>
<script>
var provinceList = ['北京市', '河北省', '浙江省'];
var cityList = [['东城区', '西城区', '海淀区'], ['廊坊市', '唐山市', '石家庄市', '承德市'], ['杭州市', '温州市', '宁波市', '嘉兴市', '绍兴市']];
var areasList = [
[
['东城区1', '东城区2', '东城区3'],
['西城区1', '西城区2', '西城区3'],
['海淀区1', '海淀区2', '海淀区3']
],
[
['廊坊市1', '廊坊市2', '廊坊市3', '廊坊市4'],
['唐山市1', '唐山市2', '唐山市3', '唐山市4'],
['石家庄市1', '石家庄市2', '石家庄市3', '石家庄市4'],
['承德市1', '承德市2', '承德市3', '承德市4']
],
[
['杭州市1', '杭州市2', '杭州市3', '杭州市4', '杭州市5'],
['温州市1', '温州市2', '温州市3', '温州市4', '温州市5'],
['宁波市1', '宁波市2', '宁波市3', '宁波市4', '宁波市5'],
['嘉兴市1', '嘉兴市2', '嘉兴市3', '嘉兴市4', '嘉兴市5'],
['绍兴市1', '绍兴市2', '绍兴市3', '绍兴市4', '绍兴市5']
]
];
//1.获取元素
var province = document.getElementById("province");
var city = document.getElementById("city");
var area = document.getElementById("area");
//2.给省的选择框赋值,
// ----使用自执行函数,避免污染全局变量-----
(function () {
for (var i = 0; i < provinceList.length; i++) {
var myOption = document.createElement("option");
myOption.innerHTML = provinceList[i];
//设置value值
myOption.value = i;
province.appendChild(myOption);
}
})();
//3.设置选择省的行为函数
province.onchange = function (e) {
city.style.display = "inline-block"; //设置第二个出现
while (city.children.length > 1) { //当省设置为“请选择”时,移除子元素
city.removeChild(city.lastElementChild);
}
while (area.children.length > 1) { //当市设置为“请选择”时,移除子元素
area.removeChild(area.lastElementChild);
}
if (cityList[this.value]) {//当设置为请选择时不显示列表
for (var i = 0; i < cityList[this.value].length; i++) { //添加市的列表
var myOption = document.createElement("option");
myOption.innerHTML = cityList[this.value][i];
//设置value值
myOption.value = i;
city.appendChild(myOption);
}
}
};
//4.设置选择市的行为函数
city.onchange = function (e) {
area.style.display = "inline-block"; //设置第二个出现
while (area.children.length > 1) { //当市设置为“请选择”时,移除子元素
area.removeChild(area.lastElementChild);
}
if (areasList[province.value][this.value]) {//当设置为"请选择"时不显示列表
for (var i = 0; i < areasList[province.value][this.value].length; i++) { //添加市的列表
var myOption = document.createElement("option");
myOption.innerHTML = areasList[province.value][this.value][i];
area.appendChild(myOption);
}
}
}
</script>
</body>
</html>

运行效果图如下:

原生JavaScript实现的简单省市县三级联动功能示例

更多关于JavaScript相关内容可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
在IE和VB中支持png图片透明效果的实现方法(vb源码打包)
Apr 01 Javascript
《JavaScript高级程序设计》阅读笔记(三) ECMAScript中的引用类型
Feb 27 Javascript
Java 正则表达式学习总结和一些小例子
Sep 13 Javascript
Javascript中产生固定结果的函数优化技巧
Jan 16 Javascript
JQuery对id中含有特殊字符的转义处理示例
Sep 06 Javascript
javascript中的return和闭包函数浅析
Jun 06 Javascript
jquery $(document).ready()和window.onload的区别浅析
Feb 04 Javascript
js组件SlotMachine实现图片切换效果制作抽奖系统
Apr 17 Javascript
各式各样的导航条效果css3结合jquery代码实现
Sep 17 Javascript
微信小程序 css使用技巧总结
Jan 09 Javascript
JS switch判断 三目运算 while 及 属性操作代码
Sep 03 Javascript
js canvas实现橡皮擦效果
Dec 20 Javascript
原生JavaScript实现精美的淘宝轮播图效果示例【附demo源码下载】
May 27 #Javascript
详细讲解vue2+vuex+axios
May 27 #Javascript
AngularJS获取json数据的方法详解
May 27 #Javascript
vue中用H5实现文件上传的方法实例代码
May 27 #Javascript
详解vue2.0脚手架的webpack 配置文件分析
May 27 #Javascript
详解如何使用webpack打包Vue工程
May 27 #Javascript
Jquery中attr与prop的区别详解
May 27 #jQuery
You might like
Protoss建筑一览
2020/03/14 星际争霸
PHP配置心得包含MYSQL5乱码解决
2006/11/20 PHP
PHP n个不重复的随机数生成代码
2009/06/23 PHP
php 注册时输入信息验证器的实现详解
2013/07/05 PHP
基于linnux+phantomjs实现生成图片格式的网页快照
2015/04/15 PHP
php使用cookie实现记住登录状态
2015/04/27 PHP
php实现的单一入口应用程序实例分析
2015/09/23 PHP
laravel5.6 框架操作数据 Eloquent ORM用法示例
2020/01/26 PHP
传智播客学习之java 反射
2009/11/22 Javascript
jQuery示例收集
2010/11/05 Javascript
运算符&amp;&amp;的三个不同层次
2013/04/07 Javascript
如何动态的导入js文件具体该怎么实现
2014/01/14 Javascript
JavaScript实现左右下拉框动态增删示例
2017/03/09 Javascript
vue-cli之router基本使用方法详解
2017/10/17 Javascript
利用jqgrid实现上移下移单元格功能
2018/11/07 Javascript
如何在JavaScript中正确处理变量
2020/12/25 Javascript
vue+element UI实现树形表格
2020/12/29 Vue.js
Python程序设计入门(5)类的使用简介
2014/06/16 Python
python避免死锁方法实例分析
2015/06/04 Python
Python的Flask框架及Nginx实现静态文件访问限制功能
2016/06/27 Python
python多进程控制学习小结
2018/10/31 Python
浅谈python 导入模块和解决文件句柄找不到问题
2018/12/15 Python
理想高通滤波实现Python opencv示例
2019/01/30 Python
python对绑定事件的鼠标、按键的判断实例
2019/07/17 Python
Django Admin中增加导出Excel功能过程解析
2019/09/04 Python
聊聊python中的循环遍历
2020/09/07 Python
墨尔本最受欢迎的复古风格品牌:Princess Highway
2018/12/21 全球购物
英国泽西岛植物:Jersey Plants Direct
2019/08/07 全球购物
二手书店创业计划书
2014/01/16 职场文书
自我鉴定书
2014/03/24 职场文书
会计专业求职信
2014/08/10 职场文书
党员教师学习党的群众路线教育实践活动心得体会
2014/10/31 职场文书
Python办公自动化PPT批量转换操作
2021/09/15 Python
CentOS7和8下安装Maven3.8.4
2022/04/07 Servers
html中相对位置与绝对位置的具体使用
2022/05/15 HTML / CSS
MutationObserver在页面水印实现起到的作用详解
2022/07/07 Javascript