js实现省市区三级联动非select下拉框版
程序员文章站
2022-03-14 08:09:54
在网上搜三级联动发现都是用option写的,突发奇想用其他方式写了一个,自我感觉效果还不错,大家感兴趣的可以看看,不说废话,大家看效果代码如下,小白写的有点乱,大家想看的就看看1.html代码<...
在网上搜三级联动发现都是用option写的,突发奇想用其他方式写了一个,自我感觉效果还不错,大家感兴趣的可以看看,不说废话,大家看效果
代码如下,小白写的有点乱,大家想看的就看看
1.html代码
<div class="box"> <section class="province">省</section> <section class="city">市</section> <section class="area">区</section> <div class="si"> </div> </div>
2.css代码
<style> .box{ width: 800px; height: 50px; margin: 20px auto; background-color: rgb(48, 49, 48); border-radius: 10px; display: flex; justify-content: center; align-items: center; } .box section{ display: inline-block; background-color: rgb(168, 165, 165); flex-grow: 1; height: 30px; margin-right: 10px; margin-left: 10px; border-radius: 5px; line-height: 30px; padding-left: 10px; } .box section:hover{ cursor: pointer; } .si{ display: none; } .box .all{ display: block; width: 740px; background-color: rgb(211, 203, 203); padding: 20px; position: absolute; border-radius: 10px; top: 57px; } .box .all:hover{ cursor: pointer; } .box .all span{ display: inline-block; width: 130px; height: 30px; font-size: 13px; padding-left: 10px; line-height: 30px; border-radius: 5px; margin-left: 10px; border: 1px solid #000; background-color: white; box-sizing: border-box; margin-top: 10px; } </style>
3.js代码
<script> // 获取内容 var data = city_code// 这个是我的数据 // 获取省市区 var province = document.queryselector(".province") var city = document.queryselector(".city") var area = document.queryselector(".area") // 获取隐藏div var si = document.queryselector(".si") province.addeventlistener("mouseover",function(){ si.classlist.add("all") // 选择省 var html = "" var all = document.queryselector(".all") for(var i = 0;i<data.length;i++){ const provincename = data[i].name const provinceid = data[i].code html += `<span id="${provinceid}">${provincename}</span>` } all.innerhtml=html var spanall = document.queryselectorall("span") for(var j =0;j<spanall.length;j++){ spanall[j].addeventlistener("click",function(){ province.innerhtml=this.innertext province.id=this.id html = "" // 选择市 for(var k = 0;k<data.length;k++){ if (data[k].code===province.id) { var citys = data[k].city for(var i = 0;i<citys.length;i++){ html +=`<span id="${citys[i].code}">${citys[i].name}</span>` } all.innerhtml=html var spanall = document.queryselectorall("span") for(var j =0;j<spanall.length;j++){ spanall[j].addeventlistener("click",function(){ city.innerhtml=this.innertext city.id=this.id html = "" //选择区 for(var k = 0;k<citys.length;k++){ if (citys[k].code===city.id) { var areas = citys[k].area for(var i = 0;i<areas.length;i++){ html +=`<span id="${areas[i].code}">${areas[i].name}</span>` } all.innerhtml=html var spanall = document.queryselectorall("span") for(var j =0;j<spanall.length;j++){ spanall[j].addeventlistener("click",function(){ area.innerhtml=this.innertext area.id=this.id si.classlist.remove("all") }) } break } } }) } break } } }) } }) </script>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。