我正在尝试使用
创建一个对象货币
期初余额
和期末余额
我有以下数据
var _ = require('underscore');
var accounts=[
{
"id":"20",
"name":"OASIS MALL-RMB Account",
"branchId":"6",
"type_id":"1",
"currency_id":"1",
"balance":"0",
"createdBy":"2",
"active":"1",
"ts":"2017-06-30 00:12:08"
},
{
"id":"21",
"name":"OASIS MALL-USD Account",
"branchId":"6",
"type_id":"1",
"currency_id":"2",
"balance":"0",
"createdBy":"2",
"active":"1",
"ts":"2017-06-30 00:12:09"
},
{
"id":"22","name":"OASIS MALL-DIRHAM Account",
"branchId":"6",
"type_id":"1",
"currency_id":"3",
"balance":"0",
"createdBy":"2",
"active":"1",
"ts":"2017-06-30 00:12:09"
},
{
"id":"23",
"name":"OASIS MALL-UGX Account",
"branchId":"6",
"type_id":"1",
"currency_id":"4",
"balance":"0",
"createdBy":"2",
"active":"1",
"ts":"2017-06-30 00:12:09"
},
{
"id":"24",
"name":"OASIS MALL-KSH Account",
"branchId":"6",
"type_id":"1",
"currency_id":"5",
"balance":"0",
"createdBy":"2",
"active":"1",
"ts":"2017-06-30 00:12:09"
}
]
var balances =[
{
"id":"101",
"branchId":"6",
"accountId":"20",
"openingBalance":"3260000",
"closingBalance":"3260000",
"date":"2017-08-15",
"ts":"2017-08-15 02:27:08"
},
{
"id":"102",
"branchId":"6",
"accountId":"21",
"openingBalance":"1882492",
"closingBalance":"1882492",
"date":"2017-08-15",
"ts":"2017-08-15 02:27:08"
},
{
"id":"103","branchId":"6",
"accountId":"22",
"openingBalance":"-3000",
"closingBalance":"-3000",
"date":"2017-08-15",
"ts":"2017-08-15 02:27:08"
},
{
"id":"104",
"branchId":"6",
"accountId":"23",
"openingBalance":"95199318",
"closingBalance":"95199318",
"date":"2017-08-15",
"ts":"2017-08-15 02:27:08"
},
{
"id":"105",
"branchId":"6",
"accountId":"24",
"openingBalance":"1847000",
"closingBalance":"1847000",
"date":"2017-08-15",
"ts":"2017-08-15 02:27:08"
}
]
我知道如何在循环和if语句中执行此操作。但我想以功能的方式做到这一点 我试过写这段代码。
var DisplayAccounts = function(accounts,balances){
var displayaccounts = _(accounts).map((x)=>{
var mybalance = _(balances)
.reduce((acc,z)=>{
acc={
currency :x.currency_id,
openingBalance : z.openingBalance,
closingBalance : z.closingBalance
};
return acc;
},{});
return mybalance;
});
return displayaccounts;
}
console.log(DisplayAccounts(accounts,balances));
但它给了我一个我不喜欢的答案。 IT给了我
[ { currency: '1',
openingBalance: '1847000',
closingBalance: '1847000' },
{ currency: '2',
openingBalance: '1847000',
closingBalance: '1847000' },
{ currency: '3',
openingBalance: '1847000',
closingBalance: '1847000' },
{ currency: '4',
openingBalance: '1847000',
closingBalance: '1847000' },
{ currency: '5',
openingBalance: '1847000',
closingBalance: '1847000' } ]
相同的期初和期末余额。我需要每种货币都有相应的期初和期末余额。
[ { currency: '1',
openingBalance: '3260000',
closingBalance: '3260000' },
{ currency: '2',
openingBalance: '1882492',
closingBalance: '1882492' },
{ currency: '3',
openingBalance: '-3000',
closingBalance: '-3000' },
{ currency: '4',
openingBalance: '95199318',
closingBalance: '95199318' },
{ currency: '5',
openingBalance: '1847000',
closingBalance: '1847000' } ]
怎么做呢?
答案 0 :(得分:2)
这不是纯粹的功能方法,但会产生预期的结果:
function displayAccounts(acc, bal) {
return acc.map(x => {
let b = bal.find(b => b.accountId === x.id);
return {
currency: x.currency_id,
openingBalance: b.openingBalance,
closingBalance: b.closingBalance
}
});
}
console.log(displayAccounts(accounts, balances));