欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生JavaScript實(shí)現(xiàn)動態(tài)省市縣三級聯(lián)動下拉框菜單實(shí)例代碼

 更新時間:2016年02月03日 15:49:58   投稿:mrr  
像平時購物選擇地址時一樣,通過選擇的省動態(tài)加載城市列表,通過選擇的城市動態(tài)加載縣區(qū)列表,從而可以實(shí)現(xiàn)省市縣的三級聯(lián)動,下面使用原生的JavaScript來實(shí)現(xiàn)這個功能,需要的朋友參考下吧

像平時購物選擇地址時一樣,通過選擇的省動態(tài)加載城市列表,通過選擇的城市動態(tài)加載縣區(qū)列表,從而可以實(shí)現(xiàn)省市縣的三級聯(lián)動,下面使用原生的JavaScript來實(shí)現(xiàn)這個功能:

先給大家展示下測試結(jié)果:

未做任何選擇時:

選擇時:

代碼如下所示:

<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>三級聯(lián)動測試</title>
<script src="jquery-2.1.4.min.js"></script>
<script type="text/javascript">
//用來獲得option元素中selected屬性為true的元素的id
function Get_Selected_Id(place){
var pro = document.getElementById(place);
var Selected_Id = pro.options[pro.selectedIndex].id;
return Selected_Id; //返回selected屬性為true的元素的id
}
//改變下一個級聯(lián)的option元素的內(nèi)容,即加載市或縣
function Get_Next_Place(This_Place_ID,Action){
var Selected_Id = Get_Selected_Id(This_Place_ID); //Selected_Id用來記錄當(dāng)前被選中的省或市的ID
if(Action=='Get_city') //從而可以在下一個級聯(lián)中加載相應(yīng)的市或縣
Add_city(Selected_Id);
else if(Action=='Get_country')
Add_country(Selected_Id);
}
//用來存儲省市區(qū)的數(shù)據(jù)結(jié)構(gòu)
var Place_dict = {
"GuangDong":{
"GuangZhou":["PanYu","HuangPu","TianHe"],
"QingYuan":["QingCheng","YingDe","LianShan"],
"FoShan":["NanHai","ShunDe","SanShui"]
},
"ShanDong":{
"JiNan":["LiXia","ShiZhong","TianQiao"],
"QingDao":["ShiNan","HuangDao","JiaoZhou"]
},
"HuNan":{
"ChangSha":["KaiFu","YuHua","WangCheng"],
"ChenZhou":["BeiHu","SuXian","YongXian"]
}
};
//加載城市選項(xiàng)
function Add_city(Province_Selected_Id){
$("#city").empty();
$("#city").append("<option>City</option>");
$("#country").empty();
$("#country").append("<option>Country</option>");
//上面的兩次清空與兩次添加是為了保持級聯(lián)的一致性
var province_dict = Place_dict[Province_Selected_Id]; //獲得一個省的字典
for(city in province_dict){ //取得省的字典中的城市
//添加內(nèi)容的同時在option標(biāo)簽中添加對應(yīng)的城市ID
var text = "<option"+" id='"+city+"'>"+city+"</option>";
$("#city").append(text);
console.log(text); //用來觀察生成的text數(shù)據(jù)
}
}
//加載縣區(qū)選項(xiàng)
function Add_country(City_Selected_Id){
$("#country").empty();
$("#country").append("<option>Country</option>");
//上面的清空與添加是為了保持級聯(lián)的一致性
var Province_Selected_ID = Get_Selected_Id("province"); //獲得被選中省的ID,從而方便在字典中加載數(shù)據(jù)
var country_list = Place_dict[Province_Selected_ID][City_Selected_Id]; //獲得城市列表
for(index in country_list){
////添加內(nèi)容的同時在option標(biāo)簽中添加對應(yīng)的縣區(qū)ID
var text = "<option"+" id=\'"+country_list[index]+"\'>"+country_list[index]+"</option>";
$("#country").append(text);
console.log(text); //用來觀察生成的text數(shù)據(jù)
}
}
</script>
</head>
<body>
<p>您的收貨地址:</p>
<select id="province" onchange="Get_Next_Place('province','Get_city')">
<option id="Not_data1">Province</option>
<option id="GuangDong" value="GuangDong">GuangDong</option>
<option id="ShanDong" value="ShanDong">ShanDong</option>
<option id="HuNan" value="HuNan">HuNan</option>
</select>
<select id="city" onchange="Get_Next_Place('city','Get_country')">
<option id="Not_data2">City</option>
</select>
<select id="country">
<option id="Not_data3">Country</option>
</select>
<br/>
</body>
</html>

當(dāng)然,省市縣三者都是動態(tài)聯(lián)動的,只要頂級的內(nèi)容發(fā)生改變,所有子級的內(nèi)容也會發(fā)生改變或被重置為City或Country.

以上所述是小編給大家分享的原生JavaScript實(shí)現(xiàn)動態(tài)省市縣三級聯(lián)動下拉框菜單實(shí)例代碼,希望對大家有所幫助。

相關(guān)文章

  • JavaScript判斷textarea值是否為空并給出相應(yīng)提示

    JavaScript判斷textarea值是否為空并給出相應(yīng)提示

    假如用戶沒有輸入數(shù)據(jù)則給出相應(yīng)提示,那么該如何來判斷呢?下面以判斷textarea值是否為空為例
    2014-09-09
  • layui實(shí)現(xiàn)三級導(dǎo)航菜單

    layui實(shí)現(xiàn)三級導(dǎo)航菜單

    這篇文章主要為大家詳細(xì)介紹了layui實(shí)現(xiàn)三級導(dǎo)航菜單,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • JavaScript中的Promise詳解

    JavaScript中的Promise詳解

    這篇文章主要介紹了JavaScript中的Promise使用詳解,promise對象是JS進(jìn)階學(xué)習(xí)中的重要知識點(diǎn),需要的朋友可以參考下
    2021-10-10
  • 基于ts的動態(tài)接口數(shù)據(jù)配置的詳解

    基于ts的動態(tài)接口數(shù)據(jù)配置的詳解

    這篇文章主要介紹了基于ts的動態(tài)接口數(shù)據(jù)配置的詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-12-12
  • JS實(shí)現(xiàn)3D圖片旋轉(zhuǎn)展示效果代碼

    JS實(shí)現(xiàn)3D圖片旋轉(zhuǎn)展示效果代碼

    這篇文章主要介紹了JS實(shí)現(xiàn)3D圖片旋轉(zhuǎn)展示效果代碼,可實(shí)現(xiàn)頁面元素的3D旋轉(zhuǎn)變換效果,涉及JavaScript動態(tài)數(shù)學(xué)運(yùn)算的相關(guān)技巧,需要的朋友可以參考下
    2015-09-09
  • 詳解js常用分割取字符串的方法

    詳解js常用分割取字符串的方法

    這篇文章主要介紹了js常用分割取字符串的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • JavaScript文本框腳本編寫的注意事項(xiàng)

    JavaScript文本框腳本編寫的注意事項(xiàng)

    這篇文章主要為大家介紹了JavaScript文本框腳本編寫的注意事項(xiàng),幫助大家更好的編寫javascript表單腳本,感興趣的小伙伴們可以參考一下
    2016-01-01
  • 詳解ajax、fetch、axios的區(qū)別

    詳解ajax、fetch、axios的區(qū)別

    本文主要介紹了詳解ajax、fetch、axios的區(qū)別,眾所周知它們都用來發(fā)送請求,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • JavaScript中的常見錯誤與異常處理分析

    JavaScript中的常見錯誤與異常處理分析

    這篇文章主要為大家信息介紹了JavaScript中的常見錯誤與異常處理的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-01-01
  • JavaScript實(shí)現(xiàn)一個簡單的圣誕游戲

    JavaScript實(shí)現(xiàn)一個簡單的圣誕游戲

    圣誕節(jié)即將來臨,大家都在發(fā)圣誕樹,小編今天就為大家介紹一個基于JavaScript實(shí)現(xiàn)的圣誕小游戲,文中的示例代碼簡單易懂,感興趣的可以學(xué)習(xí)一下
    2021-12-12

最新評論