JavaScript实现三级联动效果

发布时间 - 2026-01-11 02:21:16    点击率:

三级联动:就是平时网页上需要选择的省市县对应位置的下拉栏模块,当选择好省位置后市的下拉栏更新为已选省的,县类似。

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title>三级联动</title>
</head>
<body>
<select id="sheng">
  <option value="">-请选择-</option><!--先创建三个下拉栏,分别对应 省 市 县-->
</select>

<select id="shi">
  <option value="">-请选择-</option>
</select>

<select id="xian">
  <option value="">-请选择-</option>
</select>
<script>
  var osheng=document.getElementById("sheng");
  var oshi=document.getElementById("shi");
  var oxian=document.getElementById("xian");

  var arr_sheng=["陕西省","云南省","四川省","山西省"];<!--创建一个一维数组,存入省的值-->

  var arr_shi=[<!--创建一个二维数组,最外层每一个元素对应省-->
    ["西安市","咸阳市","宝鸡市","渭南市"],<!--数组中的第一个元素内又定义一个数组存的市的值-->
    ["昆明市","大理市","丽江市","西双版纳市"],
    ["乐山市","成都市","大同市","高新市"],
    ["太原市","屏显市","乐宝市","李伟市"]
  ];

  var arr_xian=[<!--创建一个三维数组,最外层每一个元素(对应省)-->
      [<!--数组中定义四个数组(对应市)-->
        ["西安县1","西安县2"],["咸阳市1","咸阳市2"],["宝鸡市1","宝鸡市2"],["渭南市1","渭南市2"]
      ],<!--数组中定义两个元素(对应县)-->
      [
        ["昆明市1","昆明市2"],["大理市1","大理市2"],["丽江市1","丽江市2"],["西双版纳市1","西双版纳市2"]
      ],
      [
        ["乐山市1","乐山市2"],["成都市1","成都市2"],["大同市1","大同市2"],["高新市1","高新市2"]
      ],
      [
        ["太原市1","太原市2"],["屏显市1","屏显市2"],["乐宝市1","乐宝市2"],["李伟市1","李伟市2"]
      ]
  ];

  var quanju_arr;//创建一个全局对象,用于存储一个中间数组

  function input_arr(arr,event){//封装一个函数,用于向下拉栏中添加元素
    for(var i=0;i<arr.length;i++){//下拉栏内的元素来源于数组中的元素,遍历数组
      var option=new Option(arr[i],i);//创建Option对象(这个O要大写),存入值
      event.appendChild(option);//把option添加到event对象的末尾
    }
  }

  input_arr(arr_sheng,osheng);//调用,给省下拉栏添元素

  osheng.onchange= function () {//给下拉栏绑定事件(当下拉栏元素改变时执行)
    oshi.options.length=1;//当省下拉栏改变时,清空市的下拉栏内元素
    oxian.options.length=1;//当省下拉栏改变时,清空县的下拉栏内元素
    var index=this.value;//每一个option标签都有一个value值索引,获取索引,用于数组中元素的选择
    var arr_shi_next=arr_shi[index];//获取当前选择省的市元素并赋给一个数组
    quanju_arr=arr_xian[index];//获取当前选择省中市的县元素并赋给定义的中间数组
    input_arr(arr_shi_next,oshi);//调用,给市下拉栏添元素
  }

  oshi.onchange= function () {
    oxian.options.length=1;
    var index=this.value;
    var arr_xian_next=quanju_arr[index];
    input_arr(arr_xian_next,oxian);//调用,给县下拉栏添元素
  }
</script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# JS  # 三级联动  # PHP+Mysql+Ajax+JS实现省市区三级联动  # JS制作简单的三级联动  # jquery+json 通用三级联动下拉列表  # 省市区三级联动下拉框菜单javascript版  # js实现一个省市区三级联动选择框代码分享  # javascript实现省市区三级联动下拉框菜单  # ASP+JS三级联动下拉菜单[调用数据库数据]  # 从QQ网站中提取的纯JS省市区三级联动菜单  # asp.net省市三级联动的DropDownList+Ajax的三种框架(aspnet/Jquery  # jQuery+jsp实现省市县三级联动效果(附源码)  # 大理市  # 丽江市  # 渭南市  # 咸阳市  # 乐山市  # 大同市  # 宝鸡市  # 太原市  # 西双版纳  # 昆明市  # 成都市  # 组中  # 创建一个  # 请选择  # 省下  # 西安  # 应县  # 栏内  # 清空  # 西安市 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251811 】 【 AI营销90571


相关推荐: 专业商城网站制作公司有哪些,pi商城官网是哪个?  Laravel怎么实现验证码功能_Laravel集成验证码库防止机器人注册  Laravel用户密码怎么加密_Laravel Hash门面使用教程  音响网站制作视频教程,隆霸音响官方网站?  Laravel如何保护应用免受CSRF攻击?(原理和示例)  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法  Mybatis 中的insertOrUpdate操作  如何在Windows 2008云服务器安全搭建网站?  Laravel如何处理跨站请求伪造(CSRF)保护_Laravel表单安全机制与令牌校验  如何撰写建站申请书?关键要点有哪些?  Python函数文档自动校验_规范解析【教程】  矢量图网站制作软件,用千图网的一张矢量图做公司app首页,该网站并未说明版权等问题,这样做算不算侵权?应该如何解决?  如何在不使用负向后查找的情况下匹配特定条件前的换行符  网站制作软件免费下载安装,有哪些免费下载的软件网站?  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  为什么php本地部署后css不生效_静态资源加载失败修复技巧【技巧】  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试  如何快速搭建高效简练网站?  Python正则表达式进阶教程_复杂匹配与分组替换解析  如何在万网利用已有域名快速建站?  网站制作报价单模板图片,小松挖机官方网站报价?  详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点  js实现获取鼠标当前的位置  Laravel Fortify是什么,和Jetstream有什么关系  Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧  PythonWeb开发入门教程_Flask快速构建Web应用  北京企业网站设计制作公司,北京铁路集团官方网站?  米侠浏览器网页图片不显示怎么办 米侠图片加载修复  香港服务器部署网站为何提示未备案?  BootStrap整体框架之基础布局组件  零服务器AI建站解决方案:快速部署与云端平台低成本实践  网站制作壁纸教程视频,电脑壁纸网站?  php中::能调用final静态方法吗_final修饰静态方法调用规则【解答】  Laravel Seeder填充数据教程_Laravel模型工厂Factory使用  javascript中对象的定义、使用以及对象和原型链操作小结  Laravel如何实现URL美化Slug功能_Laravel使用eloquent-sluggable生成别名【方法】  Java类加载基本过程详细介绍  Java遍历集合的三种方式  Python数据仓库与ETL构建实战_Airflow调度流程详解  javascript事件捕获机制【深入分析IE和DOM中的事件模型】  如何安全更换建站之星模板并保留数据?  通义万相免费版怎么用_通义万相免费版使用方法详细指南【教程】  Internet Explorer官网直接进入 IE浏览器在线体验版网址  微信小程序 wx.uploadFile无法上传解决办法  百度浏览器如何管理插件 百度浏览器插件管理方法  laravel怎么使用数据库工厂(Factory)生成带有关联模型的数据_laravel Factory生成关联数据方法  如何确保西部建站助手FTP传输的安全性?  如何在香港免费服务器上快速搭建网站?