本文实例讲述了原生JavaScript实现的简单省市县三级联动功能。分享给大家供大家参考,具体如下:
三级联动是我们写表单时必不可少的,比如在写收货地址时,就用到他了,最近在看原生JavaScript,从基础写起,待完善,以后再写个jquery版的
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>三级联动菜单</title> <style> select { font-family: "萝莉体 第二版"; } .hide { display: none; } </style> </head> <body> <div> <select id="province"> <option>-请选择-</option> </select> <select id="city" class="hide"> <option>-请选择-</option> </select> <select id="area" class="hide"> <option>-请选择-</option> </select> </div> <script> var provinceList = ['北京市', '河北省', '浙江省']; var cityList = [['东城区', '西城区', '海淀区'], ['廊坊市', '唐山市', '石家庄市', '承德市'], ['杭州市', '温州市', '宁波市', '嘉兴市', '绍兴市']]; var areasList = [ [ ['东城区1', '东城区2', '东城区3'], ['西城区1', '西城区2', '西城区3'], ['海淀区1', '海淀区2', '海淀区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.给省的选择框赋值, // ----使用自执行函数,避免污染全局变量----- (function () { for (var i = 0; i < provinceList.length; i++) { var myOption = document.createElement("option"); myOption.innerHTML = provinceList[i]; //设置value值 myOption.value = i; province.appendChild(myOption); } })(); //3.设置选择省的行为函数 province.onchange = function (e) { city.style.display = "inline-block"; //设置第二个出现 while (city.children.length > 1) { //当省设置为“请选择”时,移除子元素 city.removeChild(city.lastElementChild); } while (area.children.length > 1) { //当市设置为“请选择”时,移除子元素 area.removeChild(area.lastElementChild); } if (cityList[this.value]) {//当设置为请选择时不显示列表 for (var i = 0; i < cityList[this.value].length; i++) { //添加市的列表 var myOption = document.createElement("option"); myOption.innerHTML = cityList[this.value][i]; //设置value值 myOption.value = i; city.appendChild(myOption); } } }; //4.设置选择市的行为函数 city.onchange = function (e) { area.style.display = "inline-block"; //设置第二个出现 while (area.children.length > 1) { //当市设置为“请选择”时,移除子元素 area.removeChild(area.lastElementChild); } if (areasList[province.value][this.value]) {//当设置为"请选择"时不显示列表 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>
运行效果图如下:
更多关于JavaScript相关内容可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“原生JavaScript实现的简单省市县三级联动功能示例”评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新动态
20240727
20240727
- 丁当《日与夜,跟自己说晚安》[320K/MP3][98.51MB]
- 何炅.2005-漫游【中唱】【WAV+CUE】
- 何嘉莉.1998-MYDREAMS(EP)【飞图】【WAV+CUE】
- 群星.2019-天坑鷹猎电视剧原声带(EP)【智慧大狗】【FLAC分轨】
- 【雨果唱片】《春江花月夜》2020【WAV+CUE】
- 【正原唱片】女子十二乐坊《发烧国乐精粹-十二乐坊》WAV+CUE
- [黄翠珊]SusanWong-TheBestofSusanWong[WAV+CUE]
- 杜德伟.1995-BEST.LOVE(英)【滚石】【WAV+CUE】
- 杜德伟.1996-BEST.LOVE.2(英)【滚石】【WAV+CUE】
- 陈柏宇.2008-Change【SONY】【FLAC分轨】
- 丁当《日与夜,跟自己说晚安》[FLAC/分轨][285.42MB]
- 早安《Bubble Vision》[320KMP3][36.83MB]
- 叶振棠《叶振棠歌曲合集》[合集][MP3][145.9MB]
- [黄翠珊]SusanWong-ClosetoMe[SACD]dsf
- 中唱唱片群星《好歌珍藏-民歌精粹》2CD[WAV.]