JavaScript实现三级联动菜单效果

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

html部分:

rush:xhtml;"> 3级联动<a href="https://www.jb51.cc/tag/caidan/" target="_blank" class="keywords">菜单</a>
<select id="province" onchange="change(this.value);"&gt;
  <option>请选择省份</option>
</select>

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

<select id="county"&gt;
  <option>请选择县城</option>
</select>

js部分:

rush: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);
city.options[0] = op;
}else{
for (index in region[src]){
//console.log(index);
var op = new Option(index,index,false);
city.options[city.length] = op;
}
}
//记住选择省份的值
provinceName=src;
countyChange(city.value)
}

var countyChange = function(src2){
county.innerHTML = "";
if(src2 === '请选择地市'){
var op = new Option('请选择县城','请选择县城',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);
county.options[county.length] = op;
}
}
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...