添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接

如果你要将 js二维数组转换成一维数组请查看: js二维数组转换成一维数组

JS二维数组中子数组元素数相同

原生JS实现一维对象数组转换二维数组时,二维数组中每列的元素个数相同也分为两种情概况:

  • 只知二维数组的每个子数组的列数
  • 已知二维数组的行数和列数,此时一维数组的元素数最好是二维数组行数和列数的乘积(当然也可以不是)
  • 只知JS二维数组的列数

    使用该种方式能够处理完一维数组中的每一个元素。

    const arr_1d = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20];
    var arr_2d = [];
    const cols = 5;
    var row = 0;
    var col = 0;
    arr_1d.forEach((item) => {
      if (col == 0) {
        arr_2d.push([]);
        arr_2d.at(row).push(item);
        col += 1;
      } else if (col < cols) {
        arr_2d.at(row).push(item);
        col += 1;
      } else {
        row += 1;
        arr_2d.push([]);
        arr_2d.at(row).push(item);
        col = 1;
    console.log(arr_2d);
    

    代码解释:

  • 第一次col为零时,需要添加一个[]空数组,然后向空数组中添加当前元素,而且该语句只执行一次
  • 执行else时,即col == cols,这时已经时下一个子数组的第一个元素,因此要先执行row += 1,然后再添加一个[]空数组,并附加当前元素。因为子数组的第一个元素已经附加,col要赋值为1,不能赋值为0
  • 已知JS二维数组的行数和列数

    已知JS二维数组的行数和列数,可以按照只知二维数组的列数来处理,也推荐使用:只知二维数组的列数来处理,因为这种情况能完全处理完一维数组的元素。

    JS一维对象数组转换二维数组,使用数组的slice()函数最简单,示例代码:

    const arr_1d = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21];
    var arr_2d = [];
    const rows = 4;
    const cols = 5;
    for (let row=0; row<rows; row++) {
      arr_2d[row] = arr_1d.slice(row*cols, (row+1)*cols);
    console.log(arr_2d);
    

    使用双循环实现JS一维对象数组转换二维数组,代码如下:

    const arr_1d = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19];
    const arr_len = arr_1d.length;
    var arr_2d = [];
    const rows = 4;
    const cols = 5;
    for (let row=0; row<rows; row++) {
      for (let col=0; col<cols; col++) {
        if (col == 0) {
          arr_2d.push([]);
        let idx = row * cols + col;
        if ( idx == arr_len) break;
        arr_2d.at(row).push(arr_1d.at(idx));
    console.log(arr_2d);
    

    代码解释:

  • 每次col为零时,需要添加一个[]空数组,它的作用是搭建二维数组的框架,然后向空数组中添加元素,
  • push()可附加一个元素,也可以附加一个数组元素
  • 使用行数和列数的双循环时,当JS一维数组的元素个数超过行列乘积时,后面的元素就会被舍弃。
  • JS二维数组中每列的元素数不同

    原生JS实现一维对象数组转换二维数组时,如果二维数组的每列的元素数不同,那么需要给出每列的元素数,那么自然也能得知二维数组的行数,可以使用两种方式实现:

  • 使用单循环实现JS实现一维对象数组转换二维数组
  • 使用双循环实现JS实现一维对象数组转换二维数组
  • 使用JS单循环转换

    const arr_1d = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21];
    var arr_2d = [];
    const cols = [5, 4, 3, 4, 4];
    var nums = 0;
    cols.forEach((item) => {
      nums += item;
    const arr_len = arr_1d.length;
    var row = 0;
    var col = 0;
    for (let idx=0; idx<nums; idx++) {
      if (idx==arr_len) break;
      if (col == 0) {
        arr_2d.push([]);
        arr_2d.at(row).push(arr_1d.at(idx));
        col += 1;
      } else if (col < cols.at(row)) {
        arr_2d.at(row).push(arr_1d.at(idx));
        col += 1;
      } else {
        row += 1;
        arr_2d.push([]);
        arr_2d.at(row).push(arr_1d.at(idx));
        col = 1;
    console.log(arr_2d);
    

    代码解释:

  • 第一次col为零时,需要添加一个[]空数组,然后向空数组中添加当前元素,而且该语句只执行一次。
  • 执行else时,即col == cols,这时已经时下一个子数组的第一个元素,因此要先执行row += 1,然后再添加一个[]空数组,并附加当前元素。因为子数组的第一个元素已经附加,col要赋值为1,不能赋值为0
  • break 是一维数组中元素个数少于各列之和时,中断循环。
  • 循环的次数是各列之和
  • 使用JS双循环转换

    const arr_1d = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20];
    var arr_2d = [];
    const cols = [5, 4, 3, 4, 4];
    const rows = cols.length;
    var nums = 0;
    cols.forEach((item) => {
      nums += item;
    const arr_len = arr_1d.length;
    for (let row=0; row<rows; row++) {
      for (let col=0; col<cols.at(row); col++) {
        if (col == 0) {
          arr_2d.push([]);
        let idx = row * cols.at(row) + col;
        if ( idx == arr_len) break;
        arr_2d.at(row).push(arr_1d.at(idx));
    console.log(arr_2d);
    

    代码解释:

  • 每次col为零时,需要添加一个[]空数组,它的作用是搭建二维数组的框架,然后向空数组中添加元素。
  • nums为各列之和,即:二维数组中元素的个数。
  • break语句是一维数组中的元素个数少于二维数组应添加的个数时,中断循环。
  • 本文中介绍了原生JS实现一维对象数组转换二维数组,可实现二维数组中的每个子数组包含不同个数的元素。并介绍了原生JS实现一维对象数组转换二维数组的两种实现情况: JavaScript 二维数组中每列的元素数相同,即:每个子数组包含的元素的个数相同; JS 二维数组中每列的元素数不同,即:每个子数组包含的元素的个数不同。

    JavaScript 为多元素添加监听事件修改元素或属性 Javascript 为元素添加事件监听器 JavaScript 为 HTML 元素添加 CSS 样式