JS实现简单省市二级联动


Posted in Javascript onNovember 27, 2019

刚始学习java刚好看到用js实现省市二级联动的效果,就想着写篇博客,顺便检验下自己的学习成果。

好了废话少说先看看实际效果:

JS实现简单省市二级联动

技术分析:

要实现这个功能呢,首先要用到html+js

这里用建一个下拉列表,绑定onchange事件

<select onchange="changeCity(this.value)">
 <option>--请选择--</option>
 <option value="0">湖北</option>
 <option value="1">湖南</option>
 <option value="2">河北</option>
 <option value="3">河南</option>
 </select>
 <select id="city">
 
</select>

好了下面是script部分了

<script>
 //1.创建一个二维数组用于存储省份和城市
 var cities = new Array(3);
 cities[0] = new Array("武汉市","黄冈市","襄阳市","荆州市");
 cities[1] = new Array("长沙市","郴州市","株洲市","岳阳市");
 cities[2] = new Array("石家庄市","邯郸市","廊坊市","保定市");
 cities[3] = new Array("郑州市","洛阳市","开封市","安阳市");
 
 function changeCity(val){
 
 //7.获取第二个下拉列表
 var c=document.getElementById("city");
 
 //9.清空第二个下拉列表的option内容
 c.options.length=0;
 
 //2.遍历二维数组中的省份
 for(var i=0;i<cities.length;i++){
 //注意,比较的是角标
 if(val==i){
 //3.遍历用户选择的省份下的城市
 for(var j=0;j<cities[i].length;j++){
 //alert(cities[i][j]);
 //4.创建城市的文本节点
 var a = document.createTextNode(cities[i][j]);
 //5.创建option元素节点
 var b = document.createElement("option");
 //6.将城市的文本节点添加到option元素节点
 b.appendChild(a);
 //8.将option元素节点添加到第二个下拉列表中去
 c.appendChild(b);
 }
 }
 }
 }
</script>

这样这个简单的省市二级联动就完成了,是不是特别简单呢?本人因为偷懒所以只写了四个省市,如果想完善点可以自己添加省市哦。

小编再为大家分享一位网友分享的一段代码:原生js实现省市二级联动,再此谢谢作者的分享。

通过document.createElement()创建option选项,再遍历数组appendChild到select对象内,三级联动就是用三位数组和嵌套遍历来实现。

<!DOCTYPE html>
<html>
 <head>
 <meta charset="UTF-8">
 <title>js省市二级联动</title>
 </head>
 <body>
 <form name="aform" method="get" action="#">
 省份:<select id="province" name="province" onchange="changeProvince(this.selectedIndex)"></select>
 城市:<select id="city" name="city"></select>
 </form>
 </body>
</html>

<script type="text/javascript">
 var provinces=["请选择省份","北京市","天津市","上海市","重庆市","江苏省","浙江省","江西省","海南省"];
 var citys=[
 ["请选择城市"],
 ["北京市"],
 ["天津市"],
 ["上海市"],
 ["重庆市"],
 ["南京市","无锡市","徐州市","常州市","苏州市","南通市","连云港市","淮安市","盐城市","扬州市","镇江市","泰州市","宿迁市"],
 ["杭州市","宁波市","温州市","绍兴市","湖州市","嘉兴市","金华市","衢州市","台州市","丽水市","舟山"],
 ["南昌市","九江市","上饶市","抚州市","宜春市","吉安市","赣州市","景德镇","萍乡市","新余市","鹰潭市"],
 ["海口市","三亚市","三沙市","儋州市"]
 ];
 window.onload=function(){
 var province=document.getElementById("province");
 var city=document.getElementById("city");
 var index=0;
 //创建好后加入到列表中
 for(var i in provinces)
 {
 var option = document.createElement("option");
 option.text=provinces[i];
 option.value=provinces[i];
 province.appendChild(option);
 }
 var option = document.createElement("option");
 option.text=citys[index];
 option.value=citys[index];
 city.appendChild(option);
 }
 
 function changeProvince(selectedIndex){
 var city=document.getElementById("city");
 city.options.length=0;
 for(var i in citys[selectedIndex])
 {
 var option = document.createElement("option");
 option.text=citys[selectedIndex][i];
 option.value=citys[selectedIndex][i];
 city.appendChild(option);
 }
 
 }
</script>

更多关于菜单文章的精彩内容请点击专题:Javascript级联菜单特效汇总

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
简单的js表单验证函数
Oct 28 Javascript
javascript:void(0)是什么意思示例介绍
Nov 17 Javascript
jQuery实现跨域iframe接口方法调用
Mar 14 Javascript
编写高性能Javascript代码的N条建议
Oct 12 Javascript
JavaScript中的prototype原型学习指南
May 09 Javascript
微信小程序 利用css实现遮罩效果实例详解
Jan 21 Javascript
JavaScript伪数组用法实例分析
Dec 22 Javascript
Angularjs中date过滤器失效的问题及解决方法
Jul 06 Javascript
傻瓜式解读koa中间件处理模块koa-compose的使用
Oct 30 Javascript
JS函数动态传递参数的方法分析【基于arguments对象】
Jun 05 Javascript
原生js实现五子棋游戏
May 28 Javascript
JavaScript实现班级抽签小程序
May 19 Javascript
Angular value与ngValue区别详解
Nov 27 #Javascript
原生js实现二级联动菜单
Nov 27 #Javascript
微信小程序wxml列表渲染原理解析
Nov 27 #Javascript
原生js实现下拉选项卡
Nov 27 #Javascript
浅析Vue下的components模板使用及应用
Nov 27 #Javascript
d3.js 地铁轨道交通项目实战
Nov 27 #Javascript
微信小程序表单验证WxValidate的使用
Nov 27 #Javascript
You might like
模拟OICQ的实现思路和核心程序(三)
2006/10/09 PHP
PHP获取MAC地址的函数代码
2011/09/11 PHP
浅谈PHP拦截器之__set()与__get()的理解与使用方法
2016/10/18 PHP
php7新特性的理解和比较总结
2019/04/14 PHP
javascript获取URL参数与参数值的示例代码
2013/12/20 Javascript
jquery检测input checked 控件是否被选中的方法
2014/03/26 Javascript
javascript实现五星评价代码(源码下载)
2015/08/11 Javascript
JavaScript数组的栈方法与队列方法详解
2016/05/26 Javascript
微信小程序多列选择器range-key使用详解
2020/03/30 Javascript
JavaScript你不知道的一些数组方法
2017/08/18 Javascript
jQuery使用zTree插件实现可拖拽的树示例
2017/09/23 jQuery
vue实现图片上传功能
2020/05/28 Javascript
[46:09]2014 DOTA2华西杯精英邀请赛 5 25 LGD VS VG第三场
2014/05/26 DOTA
Python和perl实现批量对目录下电子书文件重命名的代码分享
2014/11/21 Python
使用Python的PIL模块来进行图片对比
2016/02/18 Python
python 3.6 tkinter+urllib+json实现火车车次信息查询功能
2017/12/20 Python
Python获取系统所有进程PID及进程名称的方法示例
2018/05/24 Python
使用python 3实现发送邮件功能
2018/06/15 Python
Python的垃圾回收机制详解
2019/08/28 Python
numpy创建单位矩阵和对角矩阵的实例
2019/11/29 Python
Python GUI编程学习笔记之tkinter界面布局显示详解
2020/03/30 Python
解决c++调用python中文乱码问题
2020/07/29 Python
Koral官方网站:女性时尚运动服
2019/04/10 全球购物
什么是Oracle的后台进程background processes?都有哪些后台进程?
2012/04/26 面试题
学前教育毕业生自荐信范文
2013/12/24 职场文书
建筑工程管理专业自荐信范文
2013/12/28 职场文书
幼儿园秋游活动方案
2014/01/21 职场文书
大学运动会入场词
2014/02/22 职场文书
中职三好学生事迹材料
2014/08/24 职场文书
九一八事变纪念日演讲稿
2014/09/14 职场文书
2014幼儿园大班工作总结
2014/11/10 职场文书
个人年底工作总结
2015/03/10 职场文书
幼儿园大班教师随笔
2015/08/14 职场文书
html5移动端禁止长按图片保存的实现
2021/04/20 HTML / CSS
vue实现书本翻页动画效果实例详解
2022/04/08 Vue.js
uniapp 微信小程序 自定义tabBar 导航
2022/04/22 Javascript