使用 JQuery 实现级联选择框

一、运行截图

在这里插入图片描述

在这里插入图片描述

二、使用步骤

1.

代码如下(示例):

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<script src="jquery/jquery-3.5.1.js"
    type="text/javascript" charset="utf-8"></script>
    <script type="text/javascript">

       function show(num){
           $("select:last").html("<option >--请选择--</option>");
           var arr=new Array();
           arr[0] =["石家庄","邯郸","唐山","张家口","廊坊"];
           arr[1] =["石家庄","邯郸","唐山","张家口","廊坊"];
           arr[2] =["石家庄","邯郸","唐山","张家口","廊坊"];
             var nums=arr[num];
             
              $.each(nums,function(){
                  var temp="<option>"+this+"</option>";
                  $("select:last").append(temp);
              })
       }
       $(document).ready(function(){
           $("select option").hover(function(){
               $("option").css("bgcolor","blue");
           });
       });
    </script>
<body>
     <select onchange="show(this.value)" align="center" margin=0>
        <option >--请选择--</option>
        <option value="0">河北省</option>
        <option value="1">辽宁省</option>
        <option value="1">山东省</option>
</select>
<select >
    <option >--请选择--</option>
</select>    
</body>
</html>






  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用htmljs实现级联选择的功能,以下是一个简单的示例代码: ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>级联选择</title> </head> <body> <form> <select id="province"> <option value="">请选择省份</option> <option value="beijing">北京</option> <option value="shanghai">上海</option> </select> <select id="city"> <option value="">请选择城市</option> </select> <select id="area"> <option value="">请选择地区</option> </select> </form> <script type="text/javascript"> //省份数据 var provinceData = [ { name: '北京', city: [ { name: '北京市', area: ['东城区', '西城区', '朝阳区', '海淀区', '丰台区'] } ] }, { name: '上海', city: [ { name: '上海市', area: ['黄浦区', '徐汇区', '长宁区', '静安区', '浦东新区'] } ] } ]; //城市数据 var cityData = {}; //地区数据 var areaData = {}; //初始化省份数据 function initProvince() { var provinceSelect = document.getElementById('province'); //添加省份数据 for (var i = 0; i < provinceData.length; i++) { var province = provinceData[i]; var option = document.createElement('option'); option.value = province.name; option.text = province.name; provinceSelect.appendChild(option); } //绑定省份选择事件 provinceSelect.onchange = function() { var citySelect = document.getElementById('city'); var areaSelect = document.getElementById('area'); //如果省份未选中,则清空城市和地区选择数据 if (provinceSelect.value === '') { citySelect.innerHTML = '<option value="">请选择城市</option>'; areaSelect.innerHTML = '<option value="">请选择地区</option>'; return; } //如果城市和地区已选中,则不需要再次加载数据 if (citySelect.value !== '' && areaSelect.value !== '') { return; } //加载城市数据 var provinceName = provinceSelect.value; if (cityData[provinceName]) { //如果已经加载过城市数据,则直接从内存中读取 var cityList = cityData[provinceName]; } else { //如果没有加载过,则从省份数据中查找对应城市数据 for (var i = 0; i < provinceData.length; i++) { if (provinceData[i].name === provinceName) { cityList = provinceData[i].city; cityData[provinceName] = cityList; break; } } } //添加城市数据 citySelect.innerHTML = '<option value="">请选择城市</option>'; for (var i = 0; i < cityList.length; i++) { var city = cityList[i]; var option = document.createElement('option'); option.value = city.name; option.text = city.name; citySelect.appendChild(option); } //清空地区数据 areaSelect.innerHTML = '<option value="">请选择地区</option>'; }; } //初始化城市数据 function initCity() { var citySelect = document.getElementById('city'); //绑定城市选择事件 citySelect.onchange = function() { var areaSelect = document.getElementById('area'); //如果城市未选中,则清空地区选择数据 if (citySelect.value === '') { areaSelect.innerHTML = '<option value="">请选择地区</option>'; return; } //如果地区已选中,则不需要再次加载数据 if (areaSelect.value !== '') { return; } //加载地区数据 var provinceName = document.getElementById('province').value; var cityName = citySelect.value; if (areaData[provinceName + cityName]) { //如果已经加载过地区数据,则直接从内存中读取 var areaList = areaData[provinceName + cityName]; } else { //如果没有加载过,则从省份数据和城市数据中查找对应地区数据 for (var i = 0; i < provinceData.length; i++) { if (provinceData[i].name === provinceName) { var cityList = provinceData[i].city; for (var j = 0; j < cityList.length; j++) { if (cityList[j].name === cityName) { areaList = cityList[j].area; areaData[provinceName + cityName] = areaList; break; } } break; } } } //添加地区数据 areaSelect.innerHTML = '<option value="">请选择地区</option>'; for (var i = 0; i < areaList.length; i++) { var area = areaList[i]; var option = document.createElement('option'); option.value = area; option.text = area; areaSelect.appendChild(option); } }; } //初始化级联选择 function init() { initProvince(); initCity(); } init(); </script> </body> </html> ``` 在该示例代码中,需要先定义省份数据、城市数据和地区数据,然后在页面加载时初始化省份选择,并绑定省份选择事件;当省份选择改变时,根据选中的省份加载对应的城市数据,并添加到城市选择中,同时清空地区选择数据;当城市选择改变时,根据选中的省份和城市加载对应的地区数据,并添加到地区选择中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值