JavaScript二维数组实现的省市联动菜单

时间:2024-06-14 22:02:56 


<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
//初始化一个二维数组存储城市列表项
var cities=[
["安庆","合肥","桐城"],
["石家庄","保定","唐山"],
["郑州","洛阳","开封"]
];
//选中某个省份时候,调用添加城市的方法
function provinceChanged(sel){
//alert("select的长度"+sel.options.length);
//sel其实就是select对象
//遍历options集合,查找选中的选项
for(var x=0;x<sel.options.length;x++)
{
var opt=sel.options[x];
if(opt.selected)
{
//给被选择的城市的select 添加option
addCityToSelect(x)
}
}
}
//添加选中省份下的城市项到city的select中
function addCityToSelect(x){
//从二维数组中找出对应的城市
var city=cities[x-1];
var citySelect=document.getElementById("select_city");
/*==================删除节点中已经存在的元素===============
在第二次或第n次调用方法的时候城市select对象中已经添加了之前添加的节点,所以有清空。
思路1:select对象的removeChild(),所以通过循环遍历可以删除字节点。
思路2:直接设置select.options.length=1可以实现相同效果。
*/
//设置城市的select对象下的options长度为1
citySelect.options.length=1;
//设置options集合的长度,删除
//citySelect.options.length=1;
for(var x=0;x<city.length;x++)
{
//创建元素节点对象
var optionName=document.createElement("option");
//给option设置显示内容
optionName.innerHTML=city[x];
//将创建的option添加到select
citySelect.appendChild(optionName);
/*
在这个地方将某一个省份下面的所有城市添加到citySelect对象下面以后
当第二次选择第二个省份的时候,第二个省份的下面的所有城市有会被追加到
citySelect节点下面。这样的效果就错了。所以要求在每次添加之前,要
对citySelect节点下面的内容进行清空。接着看:
==================删除节点中已经存在的元素===============
*/
}
}
</script>
</head>
<body>
<select onchange="provinceChanged(this);">
<!--this的含义:是指select对象调用provinceChanged(this),并且在此方法中
把对象本身作为参数传递,以便对其进行操作。 -->
<option>请选择省份</option>
<option>安徽</option>
<option>河北</option>
<option>河南</option>
</select>
<select id="select_city">
<option>请选择城市</option>
</select>
</body>
</html>

标签:省市,联动菜单
0
投稿

猜你喜欢

  • MySQL 数据查重、去重的实现语句

    2024-01-25 10:46:34
  • 人生苦短我用python python如何快速入门?

    2021-06-01 03:57:09
  • windows下mysql 5.7.20 安装配置方法图文教程

    2024-01-20 16:19:02
  • 网站LOGO设计规范的思考--2.网络LOGO的设计

    2007-10-14 11:02:00
  • java如何使用正则表达式限制特殊字符的个数

    2023-07-25 08:53:50
  • python爬虫利用代理池更换IP的方法步骤

    2023-10-04 05:50:38
  • Python seek()和tell()函数的具体使用

    2023-12-07 20:59:39
  • 在ASP.NET 2.0中操作数据之四:使用ObjectDataSource展现数据

    2024-05-13 09:15:45
  • 微信小程序上传图片功能(附后端代码)

    2023-07-24 04:21:40
  • Perl中的控制结构学习笔记

    2023-05-17 20:08:18
  • 一个ACCESS数据库数据传递的方法

    2008-03-05 11:58:00
  • 管理员必读10个重要MySQL客户启动选项

    2008-06-07 16:57:00
  • 漂亮的title提示信息

    2008-08-12 12:51:00
  • MySQL中使用表别名与字段别名的基本教程

    2024-01-12 19:39:15
  • mysql insert if not exists防止插入重复记录的方法

    2024-01-17 08:40:43
  • golang 使用sort.slice包实现对象list排序

    2023-06-21 18:25:46
  • 四个Python操作Excel的常用脚本分享

    2023-12-04 07:04:27
  • JavaScript中一个奇葩的IE浏览器判断方法

    2024-04-17 10:24:44
  • Python Django 通用视图和错误视图的使用代码

    2023-02-20 04:17:47
  • go语言Pflag Viper Cobra 核心功能使用介绍

    2024-04-25 15:26:28
  • asp之家 网络编程 m.aspxhome.com