js利用数组做省级联动

  1. 创建数组

     var 数组名称=new Array(size);

    Array:数组的关键字。

    size:数组中可存放的总数,可以动态改变数组长度。

    JavaScript Array数组对象

  2. 用数组实现省级(两层)联动
    window.onload = function(){
    	//定义数组并为其初始化
    	var cityList = new Array();
    	//下标定义为河北省,可把下标定义为0,1,然后再html中第一个selected中加入<option value="河北省">河北省</option>
    	cityList['河北省'] = ['唐山市','廊坊市'];
    	cityList['河南省'] = ['洛阳市','郑州市'];
    	cityList['湖北省'] = ['武汉市','宜昌市'];
    	
    	var menu1 = document.getElementById("menu1");
    	var menu2 = document.getElementById("menu2");
    	
    	//为第一级和第二级下拉框进行初始化
    	for(var i in cityList){//i为下标
    		//向下拉框中添加Option选项,option中有两个值,一个value,一个中间的显示值
    		menu1.add(new Option(i,i));
    	}
    	menu2.add((new Option("--","--")));
    	
    	//捕获下拉列表框一的改变事件
    	menu1.onchange = function(){
    		//获取menu1选中的下拉项
    		var menu1Val = menu1.value;
    		//清空列表框的Option选项
    		menu2.length = 0;
    		for(var j in cityList){
    			for(var k in cityList[j]){
    				if(menu1Val==j){
    					menu2.add(new Option(cityList[j][k],cityList[j][k]));
    				}
    			}
    		}
    	}
    }
    <body>
    	<select id="menu1"></select>-<select id="menu2"></select>
    </body>

    
    




  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTML数组二级联动下拉列表是一种常见的前端技术,用于实现根据用户选择的一级选项,动态加载对应的二级选项。以下是实现该功能的基本步骤: 1. 创建HTML结构:使用`<select>`标签创建一级和二级下拉列表,并为它们添加id属性,用于后续的JavaScript操作。 2. 定义数据源:创建一个JavaScript数组,包含一级选项和对应的二级选项。可以使用对象数组或者嵌套数组的形式存储数据。 3. 编写JavaScript代码:通过事件监听,当一级下拉列表的选项改变时,根据选中的值动态生成对应的二级下拉列表选项。 具体实现步骤如下: HTML结构: ```html <select id="firstSelect" onchange="changeSecondSelect()"> <option value="">请选择一级选项</option> <option value="option1">选项1</option> <option value="option2">选项2</option> <!-- 其他一级选项 --> </select> <select id="secondSelect"> <option value="">请选择二级选项</option> </select> ``` JavaScript代码: ```javascript // 定义数据源 var data = { option1: ["二级选项1-1", "二级选项1-2", "二级选项1-3"], option2: ["二级选项2-1", "二级选项2-2", "二级选项2-3"] // 其他一级选项对应的二级选项 }; // 一级下拉列表改变时触发的函数 function changeSecondSelect() { var firstSelect = document.getElementById("firstSelect"); var secondSelect = document.getElementById("secondSelect"); var selectedValue = firstSelect.value; // 清空二级下拉列表 secondSelect.innerHTML = "<option value=''>请选择二级选项</option>"; // 根据一级选项生成对应的二级选项 if (selectedValue !== "") { var options = data[selectedValue]; for (var i = 0; i < options.length; i++) { var option = document.createElement("option"); option.value = options[i]; option.innerHTML = options[i]; secondSelect.appendChild(option); } } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值