利用js的数组制作二级联动

利用js的数组制作二级联动

前面的博客我们讲解js的数组及相关属性和方法,今天我们来说一下如何利用js的数组制作二级联动效果。当然,说到二级联动,跳不过的就是多维数组。

1.多维数组
    // 多维数组:数组作为数组的项
    // 二维数组   两层数组
    // 二维数组的创建
    var arr=[1,2,3,4];//一维数组
    // 1.字面量方式声明
    var arr2=[[1,2,3],[1,2,3],[4,5,6]];
    // 2. 采用构造函数   使用 new 关键字
    var arr3=new Array([1,2,3],[4,5,6],[7,8,9]);
    // 3.先声明 后赋值
    var arr4=new Array();
    arr4[0]=["a","b","c"];
    arr4[1]=["o","p","q"];

    console.log(arr2);
    console.log(arr3);
    console.log(arr4);

    // 三维数组
    var arr5=[[[1,2,3],[4,5,6]],["a","b"]];
    console.log(arr5);

    // 二维数组的访问
    console.log(arr2[0][0]);
    arr2[0][0]="hello";
    console.log(arr2);
2.二维数组的遍历
    // 一维数组的遍历
    for(var i=0;i<arr.length;i++){
        console.log(arr[i]);
    }

    // var arr3=new Array([1,2,3],[4,5,6],[7,8,9]);
    // 如何遍历二维数组
    for(var m=0;m<arr3.length;m++){
        // console.log(arr3[m]);
        for(var n=0;n<arr3[m].length;n++){
            console.log(arr3[m][n])
        }
    }
3.二级联动

二级联动,简单来说就是要通过一个下拉列表的选项选中,从而在另一个select下拉列表中显示出对应的数据。比如我们出去旅游,在网订酒店,先选择省份,然后会显示出省份下所对应的城市。

html代码:

    <form name="form1" action="" method="get">
        <select id="a1" onchange="addOption()"></select>
        <select id="a2"></select>
    </form>

JavaScript代码:

    var city = new Array;        
    city['江苏'] = ['南京', '连云港', '苏州', '镇江'];        
    city['山东'] = ['青岛', '烟台', '济南'];         
    function allCity() {            
      var select1 = document.getElementById("a1");            
      for(var i in city) {  //这里注意遍历数组的写法
        select1.add(new Option(i, i), null);
      }   
      addOption(); // 初始化选项     
    }        
    function addOption() {            
      var select2 = document.getElementById("a2");
      var select1 = document.getElementById("a1").value; 
      select2.length = 0; //每次都先清空一下市级菜单  
      if(select1 != '请选择省份') {                
        for(var i in city[select1 ]) {    
          select2.add(new Option(city[select1][i], city[select1][i]), null);                
        }            
      }else if (sheng == '请选择省份'){              
        select2.length = 0;           
        select2.add(new Option("请选择城市", "请选择城市"), null); 
      }      
    }       
    allCity();    
  • 11
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
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); } } } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值