微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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;
}
}
}

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

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐