Как создать собственный массив с картой или другим методом в javascript?

У меня есть этот массив, который я привожу из бэкэнда:

[{
  timeDate: '2020-12-10T06:00:00.535+00:00',
  totTransApproved: 75,
  totTransDeclined: 3,
  totAmount: 5016
}, {
  timeDate: '2020-12-10T06:01:00.535+00:00',
  totTransApproved: 71,
  totTransDeclined: 4,
  totAmount: 11337
}, {
  timeDate: '2020-12-10T06:02:00.535+00:00',
  totTransApproved: 83,
  totTransDeclined: 6,
  totAmount: 14370
}]

и мне нужно преобразовать его в эту форму:

[{
  timeDate: '12/04/20 0:00',
  name: 'Approved',
  totTrans: 180,
  totAmount: 125,
}, {
  timeDate: '12/04/20 0:00',
  name: 'declined',
  totTrans: 10,
  totAmount: 12,
}]

Я пробовал так, но мне нужны оба объекта

const datums = records.map((item) => ({
  timeDate: item.timeDate,
  name: 'Aprobada',
  totTrans: item.totTransApproved,
  totAmount: item.totAmount,

}));

Как мне это сделать ?

Спасибо

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
0
164
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я думаю, вы имеете в виду, что хотите разделить каждый объект из ввода на отдельные объекты «Одобрено» и «Отклонено». Если это правильно, вы можете вернуть массив из двух объектов из map()

const records = [{timeDate: '2020-12-10T06:00:00.535+00:00',totTransApproved: 75,totTransDeclined: 3,totAmount: 5016}, {timeDate: '2020-12-10T06:01:00.535+00:00',totTransApproved: 71,totTransDeclined: 4,totAmount: 11337}, {timeDate: '2020-12-10T06:02:00.535+00:00',totTransApproved: 83,totTransDeclined: 6,totAmount: 14370}]

const datums = records.map((item) => (
  [
    { timeDate: item.timeDate,
      name: 'Approved',
      totTrans: item.totTransApproved,
      totAmount: item.totAmount
    },
    { timeDate: item.timeDate,
      name: 'Declined',
      totTrans: item.totTransDeclined,
      totAmount: item.totAmount
    }
  ]
  ));
  
  console.info(datums);
.as-console-wrapper { max-height: 100% !important; top: 0; }

или, если вы не хотите, чтобы они группировались по массиву, используйте flatMap(), чтобы сгладить возвращаемый массив объектов.

const datums = records.flatMap((item) => (
  [
    { timeDate: item.timeDate,
      name: 'Approved',
      totTrans: item.totTransApproved,
      totAmount: item.totAmount
    },
    { timeDate: item.timeDate,
      name: 'Declined',
      totTrans: item.totTransDeclined,
      totAmount: item.totAmount
    }
  ]
  ));

Вы спасли мне жизнь, большое спасибо .. Я сделал это с помощью flatMap

dany952 11.12.2020 00:34

Другие вопросы по теме