JavaScript实现三级联动菜单效果


Posted in Javascript onAugust 16, 2017

三级联动考察的应该是对于数据的处理,只要清楚其中的关系,再多几级都是一样的:

html部分:

<!DOCTYPE html>
<html>
<head>
 <meta charset="utf-8" />
 <title>3级联动菜单</title>
 <script>
 var region = {
  广东:
  {
  "广州":["广州1","广州2","广州3"],

  "珠海":["珠海1","珠海2","珠海3"],

  "佛山":["佛山1"]
  },
  湖南:
  {
  "常德":["石门","桃源","临澧","汉寿"],

  "益阳":["益阳1","益阳2","益阳3"]
  }
 }
 </script>
</head>
 <body>

 <select id="province" onchange="change(this.value);">
  <option>请选择省份</option>
 </select>

 <select id="city" onchange="countyChange(this.value);">
  <option>请选择地市</option>
 </select>

 <select id="county">
  <option>请选择县城</option>
 </select>
 <script src='test.js'></script>
 </body>
</html>

js部分:

var province = document.querySelector("#province");
 var city = document.querySelector("#city");
 var county = document.querySelector("#county");
 //二级联动不用定义你选的省份,直接用省份(key)来决定下面的市(value)值
 var provinceName = null;

 for (ele in region){
 var op = new Option(ele , ele , false , false); //new Option("文本","值",true,true).后面两个true分别表示默认被选中和有效
 //console.log(op);
 province.options[province.length] = op;
 }

 var change = function(src){
 city.innerHTML = "";
 if(src === '请选择省份'){
  var op = new Option('请选择地市' , '请选择地市' , false , false);
  city.options[0] = op;
 }else{
  for (index in region[src]){
  //console.log(index);
  var op = new Option(index , index , false , false);
  city.options[city.length] = op;
  }
 }
 //记住选择省份的值
 provinceName=src;
 countyChange(city.value)
 }

 var countyChange = function(src2){
 county.innerHTML = "";
 if(src2 === '请选择地市'){
  var op = new Option('请选择县城','请选择县城', false , false);
  county.options[0] = op;
 }else{
  for (index in region[provinceName][src2]){
  //console.log(index);
  var op = new Option(region[provinceName][src2][index] , region[provinceName][src2][index] , false , false);
  county.options[county.length] = op;
  }
 }
 }

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

Javascript 相关文章推荐
js jquery数组介绍
Jul 15 Javascript
JQuery EasyUI 数字格式化处理示例
May 05 Javascript
推荐一个封装好的getElementsByClassName方法
Dec 02 Javascript
JS+CSS实现仿msn风格选项卡效果代码
Oct 22 Javascript
js console.log打印对像与数组用法详解
Jan 21 Javascript
node+experss实现爬取电影天堂爬虫
Nov 20 Javascript
js学习总结之DOM2兼容处理this问题的解决方法
Jul 27 Javascript
Vue中的混入的使用(vue mixins)
Jun 01 Javascript
layui的table中显示图片方法
Aug 17 Javascript
vue-cli 脚手架基于Nightwatch的端到端测试环境的过程
Sep 30 Javascript
详解JavaScript对数组操作(添加/删除/截取/排序/倒序)
Apr 28 Javascript
微信小程序封装多张图片上传api代码实例
Dec 30 Javascript
ionic3 懒加载
Aug 16 #Javascript
JavaScript仿微信(电话)联系人列表滑动字母索引实例讲解(推荐)
Aug 16 #Javascript
理解 Node.js 事件驱动机制的原理
Aug 16 #Javascript
JavaScript选取(picking)和反选(rejecting)对象的属性方法
Aug 16 #Javascript
JavaScript-定时器0~9抽奖系统详解(代码)
Aug 16 #Javascript
vue实现留言板todolist功能
Aug 16 #Javascript
Angularjs中的验证input输入框只能输入数字和小数点的写法(推荐)
Aug 16 #Javascript
You might like
php中有关字符串的4个函数substr、strrchr、strstr、ereg介绍和使用例子
2014/04/24 PHP
php日期操作技巧小结
2016/06/25 PHP
JavaScript的面向对象(一)
2006/11/09 Javascript
对YUI扩展的Gird组件 Part-1
2007/03/10 Javascript
javascript里模拟sleep(两种实现方式)
2013/01/25 Javascript
IE9+已经不对document.createElement向下兼容的解决方法
2015/09/14 Javascript
jQuery simpleModal插件的使用介绍
2016/08/30 Javascript
基于Bootstrap框架菜鸟入门教程(推荐)
2017/09/17 Javascript
微信小程序实战篇之购物车的实现代码示例
2017/11/30 Javascript
vue+element实现批量删除功能的示例
2018/02/28 Javascript
vue-swiper的使用教程
2018/08/30 Javascript
微信小程序学习笔记之函数定义、页面渲染图文详解
2019/03/28 Javascript
Vue跨域请求问题解决方案过程解析
2020/08/07 Javascript
[01:04:29]DOTA2-DPC中国联赛 正赛 Phoenix vs XG BO3 第二场 1月31日
2021/03/11 DOTA
python 查找字符串是否存在实例详解
2017/01/20 Python
Python利用openpyxl库遍历Sheet的实例
2018/05/03 Python
python 每天如何定时启动爬虫任务(实现方法分享)
2018/05/21 Python
Python下使用Scrapy爬取网页内容的实例
2018/05/21 Python
python数字类型math库原理解析
2020/03/02 Python
如何利用Python识别图片中的文字
2020/05/31 Python
Python如何使用ElementTree解析xml
2020/10/12 Python
如何通过安装HomeBrew来安装Python3
2020/12/23 Python
HTML5 语音搜索只需一句代码
2013/01/03 HTML / CSS
html2canvas截图空白问题的解决
2020/03/24 HTML / CSS
英国皇家邮政海外旗舰店:Royal Mail
2018/02/21 全球购物
新加坡网上化妆品店:Best Buy World
2018/05/18 全球购物
科茨沃尔德家居商店:Scotts of Stow
2018/06/29 全球购物
大专自我鉴定范文
2013/10/01 职场文书
自动化系在校本科生求职信
2013/10/23 职场文书
关于安全演讲稿
2014/05/09 职场文书
大学生职业生涯十年规划书范文
2014/09/17 职场文书
党员评议思想汇报
2014/10/08 职场文书
2015年数学教师工作总结
2015/05/20 职场文书
开学第一周总结
2015/07/16 职场文书
python的变量和简单数字类型详解
2021/09/15 Python
进行数据处理的6个 Python 代码块分享
2022/04/06 Python