使用reduceft.logical AND &&从简单数组到二维数组

如何解决使用reduceft.logical AND &&从简单数组到二维数组

我需要将一个简单的平面数组“转换”为一个二维数组,然后我继续查看它对参数的看法。
我尝试重新创建 this answer代码,但出现此错误

console.log(array.reduce((twoDArray,n,i) => (i % 3 == 0 ? twoDArray.push([n]) : twoDArray[twoDArray.length-1].push(n)),[]));
                                                                                                                ^
TypeError: Cannot read property 'push' of undefined

问题是我没有在箭头函数的末尾添加 && twoDArray在这里你可以看到:

let array = [1,2,3,4,5,6,7,8,9];

// this works
console.log(array.reduce((twoDArray,i) => (i % 3 == 0 ? twoDArray.push([n]) : twoDArray[twoDArray.length-1].push(n)) && twoDArray,[]));

// here the second push() throws an error
console.log(array.reduce((twoDArray,[]));

现在我不明白一些事情,即:

  • 这个 && twoDArray 是如何工作的?它的目的是什么?
  • 如果此添加项仅放置在生成错误push() 之后,如何修复错误代码在到达 && 之前不应该抛出错误吗?

解决方法

这是必需的,因为 push 返回数组的新长度 - 但累加器需要是数组,而不是长度。

没有&&,并且将代码缩进多行以使其更清楚发生了什么,第二个代码等效于:

let array = [1,2,3,4,5,6,7,8,9];

// here the second push() throws an error
console.log(array.reduce((twoDArray,n,i) => {
  return (i % 3 == 0 ? twoDArray.push([n]) : twoDArray[twoDArray.length - 1].push(n))
},[]));

同:

let array = [1,i) => {
  return (
    i % 3 == 0
      ? twoDArray.push([n])
      : twoDArray[twoDArray.length - 1].push(n)
  );
},[]));

现在,问题应该清楚了:无论输入哪个条件,回调都会评估为

  return (
    i % 3 == 0
      ? someNumber
      : someNumber
  );

因为 .push 的计算结果是数组的新长度。

向其中添加 && twoDArray 使回调看起来像:

  return (
    i % 3 == 0
      ? someNumber
      : someNumber
  ) && twoDArray;

因此返回 twoDArray 而不是数字。

代码在到达 && 之前不应该抛出错误吗?

确实如此。错误在 second 迭代时抛出,当 twoDArray[twoDArray.length-1] 时,当 twoDArray 是数字时,计算结果为 undefined,因此无法推送到。但是 twoDArray 是一个数字而不是数组的问题是由先前(第一次)迭代末尾的代码导致的:缺少 && twoDArray;

这样的代码非常令人困惑。如果代码不可读,尽量不要将其压缩为一行。另一个问题是,当每次迭代中累加器是同一个对象时,.reduce 可以说是不合适的。考虑改为执行以下操作:

let array = [1,9];

const twoDArray= [];
array.forEach((n,i) => {
  i % 3 == 0
    ? twoDArray.push([n])
    : twoDArray[twoDArray.length - 1].push(n);
});
console.log(twoDArray);

并使用 if/else 代替条件运算符:

let array = [1,i) => {
  if (i % 3 === 0) twoDArray.push([n])
  else twoDArray[twoDArray.length - 1].push(n);
});
console.log(twoDArray);

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?