js城市级联功能

页面

 

 

js文件

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用html和js实现级联选择框的功能,以下是一个简单的示例代码: ``` <!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、付费专栏及课程。

余额充值