微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

将每个项目与其下一个项目进行比较,并通过比较找出每个项目的大小并将结果推送到每个新数组

如何解决将每个项目与其下一个项目进行比较,并通过比较找出每个项目的大小并将结果推送到每个新数组

我有一个像下面这样的数组。如何找到数组中的每个值与其下一个值相比是小还是大。我想将结果推送到一个新数组中,就像这个数组一样。如果项目相同,则为空。

const array = [
[7,10,9,13,11,12,7,8,8],[0,0],[6,5,6,6],[7,7],63,58,65,55,68,43,57,70,55],[29,26,28,27,29,30,33,32,31,29],[3,3,1,3]
];

这是我的代码,但不起作用。

const items = [];
  function getoutRank() {
array.map((singleKey,index) => {
  console.log("SINGLE KEY",singleKey);
  for (let i = 0; i < singleKey.length; i++) {
    if (singleKey[i + 1] > singleKey[i]) {
      return items.push(<span key={index}>Down</span>);
    }
    if (singleKey[i + 1] === singleKey[i]) {
      return items.push(<span key={index} />);
    }
    return items.push(<li key={index}>Up</li>);
  }
});}

getoutRank();

解决方法

对于每个singleKey,应该返回一个包含所有比较结果的数组。试试这个:

const array = [
  [7,10,9,13,11,12,7,8,8],[0,0],[6,5,6,6],[7,7],63,58,65,55,68,43,57,70,55],[29,26,28,27,29,30,33,32,31,29],[3,3,1,3]
];

let items = [];

function getOutRank() {
  items = array.map((singleKey,index) => {
    var compare = [];
    
    for (let i = 0; i < singleKey.length - 1; i++) {
      if (singleKey[i + 1] > singleKey[i]) {
        compare.push(`<span key=${index}>Down</span>`);
      } else if (singleKey[i + 1] === singleKey[i]) {
        compare.push(`<span key=${index}>Equal</span>`);
      } else {
        compare.push(`<li key=${index}>Up</li>`);
      }
    }
    
    return compare;
  });
}

getOutRank();
console.log(items);

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