I have an array of objects:
let arr = [
{date: '2021/01/23', a1: 'text1', a2: 'text2' },
{date: '2021/11/21', a1: 'text1', a2: 'text2' },
{date: '2020/12/22', a1: 'text1', a2: 'text2' },
{date: '2021/12/08', a1: 'text1', a2: 'text2' },
{date: '2020/12/14', a1: 'text1', a2: 'text2' },
{date: '2021/10/25', a1: 'text1', a2: 'text2' },
{date: '2021/12/04', a1: 'text1', a2: 'text2' },
]
How can I filter array of objects for each month with year, like :
'December 21' = [
{date: '2021/12/04', a1: 'text1', a2: 'text2' },
{date: '2021/12/08', a1: 'text1', a2: 'text2' }
]
'January 21' = [
{date: '2021/01/23', a1: 'text1', a2: 'text2' }
]
'December 20' = [
{date: '2020/12/22', a1: 'text1', a2: 'text2' }
]
Thanks in advance!:)
CodePudding user response:
You can try something like this:
// Your input
let arr = [
{date: '2021/01/23', a1: 'text1', a2: 'text2' },
{date: '2021/11/21', a1: 'text1', a2: 'text2' },
{date: '2020/12/22', a1: 'text1', a2: 'text2' },
{date: '2021/12/08', a1: 'text1', a2: 'text2' },
{date: '2020/12/14', a1: 'text1', a2: 'text2' },
{date: '2021/10/25', a1: 'text1', a2: 'text2' },
{date: '2021/12/04', a1: 'text1', a2: 'text2' },
];
// Month dictionary
const monthNames = [ "January", "February", "March", "April", "May", "June",
"July", "August", "September", "October", "November", "December" ];
// Get what you want
const result = arr.reduce((acc, el) => {
// Extract year & month from date
const [ year, month ] = el.date.split('/');
// Get label in 'Month YY' format
const label = monthNames[ month - 1] ' ' year.slice(2);
// Add object key to result if necessary
if (!acc[label]) acc[label] = [];
// Save element
acc[label].push(el);
return acc;
}, {});
console.log(result);
Refs: Array.prototype.reduce()
CodePudding user response:
I would do something like this:
const filterArr = (month, year) => arr.filter(x => {
const splitDate = x.date.split('/');
return splitDate[0] === year && splitDate[1] === month;
});
// Usage
filterArr("10", "2021");
EDIT: If you want to use the name of the month try this:
const monthNames = ["January", "February", "March", "April", "May", "June", "July",
"August", "September", "October", "November", "December"];
const monthNameToNumber = (month) => (monthNames.indexOf(month) 1)
.toString().padStart(2, '0');
// Usage
monthNameToNumber("December"); // "12"
CodePudding user response:
You can use forEach method to iterate from the array and save everything in an object. Like this:
let arr = [
{date: '2021/01/23', a1: 'text1', a2: 'text2' },
{date: '2021/11/21', a1: 'text1', a2: 'text2' },
{date: '2020/12/22', a1: 'text1', a2: 'text2' },
{date: '2021/12/08', a1: 'text1', a2: 'text2' },
{date: '2020/12/14', a1: 'text1', a2: 'text2' },
{date: '2021/10/25', a1: 'text1', a2: 'text2' },
{date: '2021/12/04', a1: 'text1', a2: 'text2' },
];
filteredArr = {};
arr.forEach((obj) => {
const newDate = new Date(obj.date);
const stringMonthAndYear = newDate.toLocaleString('default', { month: 'long' }) ' ' newDate.getFullYear();
if (filteredArr[stringMonthAndYear] && filteredArr[stringMonthAndYear].length) {
filteredArr[stringMonthAndYear].push(obj);
} else {
filteredArr[stringMonthAndYear] = [obj];
}
});
console.log(filteredArr);
CodePudding user response:
Try this
const month = ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'];
let arr = [
{ date: '2021/01/23', a1: 'text1', a2: 'text2' },
{ date: '2021/11/21', a1: 'text1', a2: 'text2' },
{ date: '2020/12/22', a1: 'text1', a2: 'text2' },
{ date: '2021/12/08', a1: 'text1', a2: 'text2' },
{ date: '2020/12/14', a1: 'text1', a2: 'text2' },
{ date: '2021/10/25', a1: 'text1', a2: 'text2' },
{ date: '2021/12/04', a1: 'text1', a2: 'text2' },
];
let obj = {};
for (const row of arr) {
const date = new Date(Date.parse(row.date));
let key = `${month[date.getMonth()]} ${date.getFullYear()}`;
if(!obj[key]) obj[key] = [];
obj[key].push(row);
}