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 相关文章推荐
基于jquery &amp; json的省市区联动代码
Jun 26 Javascript
JS继承--原型链继承和类式继承
Apr 08 Javascript
查找iframe里元素的方法可传参
Sep 11 Javascript
JS实现多物体缓冲运动实例代码
Nov 29 Javascript
JavaScript Ajax编程 应用篇
Jul 02 Javascript
javascript 产生随机数的几种方法总结
Sep 26 Javascript
解决vue2.0 element-ui中el-upload的before-upload方法返回false时submit()不生效问题
Aug 24 Javascript
vue动画打包后失效问题的解决方法
Sep 18 Javascript
Vue实现base64编码图片间的切换功能
Dec 04 Javascript
vue 在methods中调用mounted的实现操作
Aug 07 Javascript
解决vue单页面应用打包后相对路径、绝对路径相关问题
Aug 14 Javascript
在vue项目中引用Antv G2,以饼图为例讲解
Oct 28 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动态生成静态HTML网页的代码
2010/03/04 PHP
PHP速成大法
2015/01/30 PHP
windows系统php环境安装swoole具体步骤
2021/03/04 PHP
jQuery 页面 Mask实现代码
2010/01/09 Javascript
锋利的jQuery jQuery中的DOM操作
2010/03/21 Javascript
Javascript writable特性介绍
2015/02/27 Javascript
JavaScript中的Function函数
2015/08/27 Javascript
JavaScript中字符串与Unicode编码互相转换的实现方法
2015/12/18 Javascript
jQuery遍历json的方法(推荐)
2016/06/12 Javascript
郁闷!ionic中获取ng-model绑定的值为undefined如何解决
2016/08/27 Javascript
js正则表达式惰性匹配和贪婪匹配用法分析
2016/12/26 Javascript
JavaScript的for循环中嵌套一个点击事件的问题解决
2017/03/03 Javascript
JavaScript之Map和Set_动力节点Java学院整理
2017/06/29 Javascript
详细分析单线程JS执行问题
2017/11/22 Javascript
jQuery实现点击旋转,再点击恢复初始状态动画效果示例
2018/12/11 jQuery
使用VueRouter的addRoutes方法实现动态添加用户的权限路由
2019/06/03 Javascript
浅谈Django自定义模板标签template_tags的用处
2017/12/20 Python
python3 判断列表是一个空列表的方法
2018/05/04 Python
Python 实现的 Google 批量翻译功能
2019/08/26 Python
python匿名函数的使用方法解析
2019/10/10 Python
利用Python脚本批量生成SQL语句
2020/03/04 Python
python把一个字符串切开的实例方法
2020/09/27 Python
纯DOM+CSS3实现简单的小风车动画
2016/09/27 HTML / CSS
惊艳的手工时装首饰:Migonne Gavigan
2018/02/23 全球购物
Beauty Expert美国/加拿大:购买奢侈美容产品
2018/12/05 全球购物
俄罗斯鲜花递送:AMF
2020/04/24 全球购物
葛优非诚勿扰搞笑征婚台词
2014/03/17 职场文书
建议书的格式
2014/05/12 职场文书
地下停车场租赁协议范本
2014/10/07 职场文书
师德师风自查总结
2014/10/14 职场文书
2014年个人技术工作总结
2014/12/08 职场文书
婚礼父母答谢词
2015/01/04 职场文书
青涩记忆观后感
2015/06/18 职场文书
《少年闰土》教学反思
2016/02/18 职场文书
python实现简单的井字棋
2021/05/26 Python
通过Qt连接OpenGauss数据库的详细教程
2021/06/23 PostgreSQL