js實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)非select下拉框版
在網(wǎng)上搜三級(jí)聯(lián)動(dòng)發(fā)現(xiàn)都是用option寫的,突發(fā)奇想用其他方式寫了一個(gè),自我感覺效果還不錯(cuò),大家感興趣的可以看看,不說廢話,大家看效果



代碼如下,小白寫的有點(diǎn)亂,大家想看的就看看
1.html代碼
<div class="box">
<section class="province">省</section>
<section class="city">市</section>
<section class="area">區(qū)</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>
// 獲取內(nèi)容
var data = city_code// 這個(gè)是我的數(shù)據(jù)
// 獲取省市區(qū)
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 = ""
//選擇區(qū)
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>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- PHP+Mysql+Ajax+JS實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)
- javascript實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)下拉框菜單
- 省市區(qū)三級(jí)聯(lián)動(dòng)下拉框菜單javascript版
- js實(shí)現(xiàn)一個(gè)省市區(qū)三級(jí)聯(lián)動(dòng)選擇框代碼分享
- 從QQ網(wǎng)站中提取的純JS省市區(qū)三級(jí)聯(lián)動(dòng)菜單
- JSON+Jquery省市區(qū)三級(jí)聯(lián)動(dòng)
- 原生js實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)代碼分享
- vue.js模仿京東省市區(qū)三級(jí)聯(lián)動(dòng)的選擇組件實(shí)例代碼
- javascript實(shí)現(xiàn)簡(jiǎn)單的省市區(qū)三級(jí)聯(lián)動(dòng)
- javascript省市區(qū)三級(jí)聯(lián)動(dòng)下拉框菜單實(shí)例演示
相關(guān)文章
JS創(chuàng)建對(duì)象的十種方式總結(jié)
面向?qū)ο笫且环N重要的編程范式,如何靈活的創(chuàng)建對(duì)象,是對(duì)編程基本功的考驗(yàn),本來我們來探討一下JavaScript中創(chuàng)建對(duì)象的十種方式,感興趣的小伙伴可以了解下2023-10-10
基于JavaScript的數(shù)據(jù)結(jié)構(gòu)隊(duì)列動(dòng)畫實(shí)現(xiàn)示例解析
這篇文章主要介紹了基于JavaScript的數(shù)據(jù)結(jié)構(gòu)隊(duì)列動(dòng)畫實(shí)現(xiàn)示例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08
attachEvent的使用方法與傳遞參數(shù)[IE|firefox]
attachEvent的使用方法與傳遞參數(shù)[IE|firefox]...2007-05-05
用Javascript實(shí)現(xiàn)錨點(diǎn)(Anchor)間平滑跳轉(zhuǎn)
本文介紹的方法,實(shí)現(xiàn)了錨點(diǎn)(Anchor)間平滑跳轉(zhuǎn),效果非常不錯(cuò)。2009-09-09
GoJs節(jié)點(diǎn)繪圖模板之go.Node使用示例詳解
這篇文章主要為大家介紹了GoJs節(jié)點(diǎn)繪圖模板go.Node使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04

