当前位置:Gxlcms > JavaScript > 原生JavaScript实现的简单省市县三级联动功能示例

原生JavaScript实现的简单省市县三级联动功能示例

时间:2021-07-01 10:21:17 帮助过:38人阅读

本文实例讲述了原生JavaScript实现的简单省市县三级联动功能。分享给大家供大家参考,具体如下:

三级联动是我们写表单时必不可少的,比如在写收货地址时,就用到他了,最近在看原生JavaScript,从基础写起,待完善,以后再写个jquery版的

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>三级联动菜单</title>
  6. <style>
  7. select {
  8. font-family: "萝莉体 第二版";
  9. }
  10. .hide {
  11. display: none;
  12. }
  13. </style>
  14. </head>
  15. <body>
  16. <div>
  17. <select id="province">
  18. <option>-请选择-</option>
  19. </select>
  20. <select id="city" class="hide">
  21. <option>-请选择-</option>
  22. </select>
  23. <select id="area" class="hide">
  24. <option>-请选择-</option>
  25. </select>
  26. </div>
  27. <script>
  28. var provinceList = ['北京市', '河北省', '浙江省'];
  29. var cityList = [['东城区', '西城区', '海淀区'], ['廊坊市', '唐山市', '石家庄市', '承德市'], ['杭州市', '温州市', '宁波市', '嘉兴市', '绍兴市']];
  30. var areasList = [
  31. [
  32. ['东城区1', '东城区2', '东城区3'],
  33. ['西城区1', '西城区2', '西城区3'],
  34. ['海淀区1', '海淀区2', '海淀区3']
  35. ],
  36. [
  37. ['廊坊市1', '廊坊市2', '廊坊市3', '廊坊市4'],
  38. ['唐山市1', '唐山市2', '唐山市3', '唐山市4'],
  39. ['石家庄市1', '石家庄市2', '石家庄市3', '石家庄市4'],
  40. ['承德市1', '承德市2', '承德市3', '承德市4']
  41. ],
  42. [
  43. ['杭州市1', '杭州市2', '杭州市3', '杭州市4', '杭州市5'],
  44. ['温州市1', '温州市2', '温州市3', '温州市4', '温州市5'],
  45. ['宁波市1', '宁波市2', '宁波市3', '宁波市4', '宁波市5'],
  46. ['嘉兴市1', '嘉兴市2', '嘉兴市3', '嘉兴市4', '嘉兴市5'],
  47. ['绍兴市1', '绍兴市2', '绍兴市3', '绍兴市4', '绍兴市5']
  48. ]
  49. ];
  50. //1.获取元素
  51. var province = document.getElementById("province");
  52. var city = document.getElementById("city");
  53. var area = document.getElementById("area");
  54. //2.给省的选择框赋值,
  55. // ----使用自执行函数,避免污染全局变量-----
  56. (function () {
  57. for (var i = 0; i < provinceList.length; i++) {
  58. var myOption = document.createElement("option");
  59. myOption.innerHTML = provinceList[i];
  60. //设置value值
  61. myOption.value = i;
  62. province.appendChild(myOption);
  63. }
  64. })();
  65. //3.设置选择省的行为函数
  66. province.onchange = function (e) {
  67. city.style.display = "inline-block"; //设置第二个出现
  68. while (city.children.length > 1) { //当省设置为“请选择”时,移除子元素
  69. city.removeChild(city.lastElementChild);
  70. }
  71. while (area.children.length > 1) { //当市设置为“请选择”时,移除子元素
  72. area.removeChild(area.lastElementChild);
  73. }
  74. if (cityList[this.value]) {//当设置为请选择时不显示列表
  75. for (var i = 0; i < cityList[this.value].length; i++) { //添加市的列表
  76. var myOption = document.createElement("option");
  77. myOption.innerHTML = cityList[this.value][i];
  78. //设置value值
  79. myOption.value = i;
  80. city.appendChild(myOption);
  81. }
  82. }
  83. };
  84. //4.设置选择市的行为函数
  85. city.onchange = function (e) {
  86. area.style.display = "inline-block"; //设置第二个出现
  87. while (area.children.length > 1) { //当市设置为“请选择”时,移除子元素
  88. area.removeChild(area.lastElementChild);
  89. }
  90. if (areasList[province.value][this.value]) {//当设置为"请选择"时不显示列表
  91. for (var i = 0; i < areasList[province.value][this.value].length; i++) { //添加市的列表
  92. var myOption = document.createElement("option");
  93. myOption.innerHTML = areasList[province.value][this.value][i];
  94. area.appendChild(myOption);
  95. }
  96. }
  97. }
  98. </script>
  99. </body>
  100. </html>

运行效果图如下:

更多关于JavaScript相关内容可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》

希望本文所述对大家JavaScript程序设计有所帮助。

人气教程排行