原生JavaScript實(shí)現(xiàn)的簡(jiǎn)單省市縣三級(jí)聯(lián)動(dòng)功能示例
本文實(shí)例講述了原生JavaScript實(shí)現(xiàn)的簡(jiǎn)單省市縣三級(jí)聯(lián)動(dòng)功能。分享給大家供大家參考,具體如下:
三級(jí)聯(lián)動(dòng)是我們寫表單時(shí)必不可少的,比如在寫收貨地址時(shí),就用到他了,最近在看原生JavaScript,從基礎(chǔ)寫起,待完善,以后再寫個(gè)jquery版的
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>三級(jí)聯(lián)動(dòng)菜單</title>
<style>
select {
font-family: "蘿莉體 第二版";
}
.hide {
display: none;
}
</style>
</head>
<body>
<div>
<select id="province">
<option>-請(qǐng)選擇-</option>
</select>
<select id="city" class="hide">
<option>-請(qǐng)選擇-</option>
</select>
<select id="area" class="hide">
<option>-請(qǐng)選擇-</option>
</select>
</div>
<script>
var provinceList = ['北京市', '河北省', '浙江省'];
var cityList = [['東城區(qū)', '西城區(qū)', '海淀區(qū)'], ['廊坊市', '唐山市', '石家莊市', '承德市'], ['杭州市', '溫州市', '寧波市', '嘉興市', '紹興市']];
var areasList = [
[
['東城區(qū)1', '東城區(qū)2', '東城區(qū)3'],
['西城區(qū)1', '西城區(qū)2', '西城區(qū)3'],
['海淀區(qū)1', '海淀區(qū)2', '海淀區(qū)3']
],
[
['廊坊市1', '廊坊市2', '廊坊市3', '廊坊市4'],
['唐山市1', '唐山市2', '唐山市3', '唐山市4'],
['石家莊市1', '石家莊市2', '石家莊市3', '石家莊市4'],
['承德市1', '承德市2', '承德市3', '承德市4']
],
[
['杭州市1', '杭州市2', '杭州市3', '杭州市4', '杭州市5'],
['溫州市1', '溫州市2', '溫州市3', '溫州市4', '溫州市5'],
['寧波市1', '寧波市2', '寧波市3', '寧波市4', '寧波市5'],
['嘉興市1', '嘉興市2', '嘉興市3', '嘉興市4', '嘉興市5'],
['紹興市1', '紹興市2', '紹興市3', '紹興市4', '紹興市5']
]
];
//1.獲取元素
var province = document.getElementById("province");
var city = document.getElementById("city");
var area = document.getElementById("area");
//2.給省的選擇框賦值,
// ----使用自執(zhí)行函數(shù),避免污染全局變量-----
(function () {
for (var i = 0; i < provinceList.length; i++) {
var myOption = document.createElement("option");
myOption.innerHTML = provinceList[i];
//設(shè)置value值
myOption.value = i;
province.appendChild(myOption);
}
})();
//3.設(shè)置選擇省的行為函數(shù)
province.onchange = function (e) {
city.style.display = "inline-block"; //設(shè)置第二個(gè)出現(xiàn)
while (city.children.length > 1) { //當(dāng)省設(shè)置為“請(qǐng)選擇”時(shí),移除子元素
city.removeChild(city.lastElementChild);
}
while (area.children.length > 1) { //當(dāng)市設(shè)置為“請(qǐng)選擇”時(shí),移除子元素
area.removeChild(area.lastElementChild);
}
if (cityList[this.value]) {//當(dāng)設(shè)置為請(qǐng)選擇時(shí)不顯示列表
for (var i = 0; i < cityList[this.value].length; i++) { //添加市的列表
var myOption = document.createElement("option");
myOption.innerHTML = cityList[this.value][i];
//設(shè)置value值
myOption.value = i;
city.appendChild(myOption);
}
}
};
//4.設(shè)置選擇市的行為函數(shù)
city.onchange = function (e) {
area.style.display = "inline-block"; //設(shè)置第二個(gè)出現(xiàn)
while (area.children.length > 1) { //當(dāng)市設(shè)置為“請(qǐng)選擇”時(shí),移除子元素
area.removeChild(area.lastElementChild);
}
if (areasList[province.value][this.value]) {//當(dāng)設(shè)置為"請(qǐng)選擇"時(shí)不顯示列表
for (var i = 0; i < areasList[province.value][this.value].length; i++) { //添加市的列表
var myOption = document.createElement("option");
myOption.innerHTML = areasList[province.value][this.value][i];
area.appendChild(myOption);
}
}
}
</script>
</body>
</html>
運(yùn)行效果圖如下:

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript動(dòng)畫特效與技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- PHP+Mysql+Ajax+JS實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)
- JS制作簡(jiǎn)單的三級(jí)聯(lián)動(dòng)
- jquery+json 通用三級(jí)聯(lián)動(dòng)下拉列表
- js實(shí)現(xiàn)一個(gè)省市區(qū)三級(jí)聯(lián)動(dòng)選擇框代碼分享
- 省市區(qū)三級(jí)聯(lián)動(dòng)下拉框菜單javascript版
- ASP+JS三級(jí)聯(lián)動(dòng)下拉菜單[調(diào)用數(shù)據(jù)庫(kù)數(shù)據(jù)]
- 從QQ網(wǎng)站中提取的純JS省市區(qū)三級(jí)聯(lián)動(dòng)菜單
- asp.net省市三級(jí)聯(lián)動(dòng)的DropDownList+Ajax的三種框架(aspnet/Jquery/ExtJs)示例
- jQuery+jsp實(shí)現(xiàn)省市縣三級(jí)聯(lián)動(dòng)效果(附源碼)
- js操縱跨frame的聯(lián)動(dòng)select下拉選項(xiàng)實(shí)例介紹
- 原生js三級(jí)聯(lián)動(dòng)的簡(jiǎn)單實(shí)現(xiàn)代碼
- js實(shí)現(xiàn)簡(jiǎn)單的省市縣三級(jí)聯(lián)動(dòng)效果實(shí)例
相關(guān)文章
微信小程序轉(zhuǎn)發(fā)事件實(shí)現(xiàn)解析
這篇文章主要介紹了微信小程序轉(zhuǎn)發(fā)事件實(shí)現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10
Javascript之高級(jí)數(shù)組API的使用實(shí)例
今天小編就為大家分享一篇關(guān)于Javascript之高級(jí)數(shù)組API的使用實(shí)例,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2019-03-03
實(shí)現(xiàn)JavaScript中數(shù)據(jù)響應(yīng)的方法總結(jié)
JavaScript 數(shù)據(jù)響應(yīng)是一種重要的前端開發(fā)概念,是指在應(yīng)用程序中的數(shù)據(jù)發(fā)生變化時(shí),能夠自動(dòng)更新與這些數(shù)據(jù)相關(guān)的用戶界面(UI)部分的能力,本文我們來總結(jié)一下目前可以簡(jiǎn)單實(shí)現(xiàn) JavaScript 中的數(shù)據(jù)響應(yīng)的方法,需要的朋友可以參考下2023-09-09
70+漂亮且極具親和力的導(dǎo)航菜單設(shè)計(jì)國(guó)外網(wǎng)站推薦
網(wǎng)站可用性是任何網(wǎng)站的基本要素,而可用的導(dǎo)航更是網(wǎng)站所必需的要素之一。導(dǎo)航?jīng)Q定了用戶如何與網(wǎng)站進(jìn)行交互。如果沒有了可用的導(dǎo)航,那么網(wǎng)站內(nèi)容就會(huì)變得毫無用處。2011-09-09
JS計(jì)算距當(dāng)前時(shí)間的時(shí)間差實(shí)例
下面小編就為大家分享一篇JS計(jì)算距當(dāng)前時(shí)間的時(shí)間差實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2017-12-12
js中forEach的用法之forEach與for之間的區(qū)別
這篇文章主要介紹了js中forEach的用法之forEach與for之間的區(qū)別,forEach() 調(diào)用數(shù)組的每個(gè)元素,并將元素傳遞給回調(diào)函數(shù),下面更多詳細(xì)介紹需要的小伙伴可以參考一下2022-03-03

