我有这样一个数组
我只想分期付款,带支票=真和付款。
我有这个数组
0: {
checked: true,
code: 100.
paymant: Array(2)
{
0: {data: 03/12/2021, checked: true},
1: {data: 03/12/2021}
}
},
1: {
code: 100.
paymant: Array(2)
{
0: {data: 03/12/2021},
1: {data: 03/12/2021}
}
}
// Real Data
const data = [
{
checked: true,
code: 100,
payments: [
{data: 'checked', checked: true},
{data: 'not-checked'}
]
},
{
code: 100,
payments: [
{data: 'not-checked'},
{data: 'not-checked'}
]
}
];我想要这个
0: {
checked: true,
code: 100.
paymant: Array(1)
{
0: {data: 03/12/2021, checked: true},
}
},我试着做这件事但没有工作
installments.filter(i => i.checked).filter(i => i.paymant.filter(p => p.checked))发布于 2021-12-03 19:03:44
第一个过滤器是直接向前的,但是您需要重新构建支付数组,所以它只包含选中的条目。
const data = [
{
checked: true,
code: 100,
payments: [
{data: 'checked', checked: true},
{data: 'not-checked'}
]
},
{
code: 100,
payments: [
{data: 'not-checked'},
{data: 'not-checked'}
]
}
];
const checked = (item) => item && item.checked;
const paymentCheckedMapper = (item) => (
{...item, payments: item.payments.filter(checked)}
);
data.filter(checked).map(paymentCheckedMapper)发布于 2021-12-03 19:10:17
因为您需要混合和匹配filter和map。您可以在这里使用reduce。不需要过滤然后映射,它将花费性能问题。
const data = [
{
checked: true,
code: 100,
paymant: [
{ data: 03 / 12 / 2021, checked: true },
{ data: 03 / 12 / 2021 },
],
},
{
code: 101,
paymant: [{ data: 03 / 12 / 2021 }, { data: 03 / 12 / 2021 }],
},
];
const getPaid = (records = []) => {
return records.reduce((acc, record) => {
if (!record.checked) return acc;
const paymant = record.paymant.filter((paymant) => paymant.checked);
if (paymant.length) {
acc.push({ ...record, paymant });
}
return acc;
}, []);
};
console.log(getPaid(data));
https://stackoverflow.com/questions/70219349
复制相似问题