首页 > 解决方案 > 通过将属性相乘来更新数组总属性

问题描述

所以我有一个数组,我想通过将值乘以 qty 来改变总数(我把它改成了英文),我终于想出了如何得到总数。现在我一直在更新正确属性中的总数。

我认为一个循环或其他东西,但它对我来说还没有意义,我如何才能清楚地说明它应该用正确的价值和数量之和更新正确的属性。

然后我稍后会制作它,以便您可以在表单中更改它并添加到它,但这是更进一步的一步。我一直在看 Array Map 和 ForEach 来改变它。但我有点卡住了

预期的输出将是:

{omschrijving:“育雏”,价值:1,数量:3,总计:3},

{omschrijving:“Brocolli”,价值:0.99,数量:2,总计:1.98},

{omschrijving:“Krentenbollen”,价值:1.20,数量:4,总计:4.80},

{omschrijving:“Noten”,价值:2.99,数量:2,总计:5.98}

我也意识到我的 forEach 输出 5 个数字?:O

我还从属性中删除了我的手动总计,因为我想更改它。

现在它给出了一个错误:) 所以我再次填写手册。

    let product =  [
{omschrijving:"Brood", value:1, qty:3, total:},
{omschrijving:"Brocolli", value:0.99, qty:2, total:},
{omschrijving:"Krentenbollen", value:1.20, qty:4, total:},
{omschrijving:"Noten", value:2.99, qty:2, total:}
]



product.forEach(function (arrayItem) {
    var x = arrayItem.value * arrayItem.qty;
    console.log(x);
});

标签: javascriptarrayspropertiesupdating

解决方案


这是使用简单 for 循环的解决方案

let product =  [
{omschrijving:"Brood", value:1, qty:3},
{omschrijving:"Brocolli", value:0.99, qty:2},
{omschrijving:"Krentenbollen", value:1.20, qty:4},
{omschrijving:"Noten", value:2.99, qty:2}
]

for(let i=0;i<product.length;i++)
{
  product[i].total = product[i].value*product[i].qty;
}
console.log(product);

使用 forEach 方法

let product =  [
    {omschrijving:"Brood", value:1, qty:3},
    {omschrijving:"Brocolli", value:0.99, qty:2},
    {omschrijving:"Krentenbollen", value:1.20, qty:4},
    {omschrijving:"Noten", value:2.99, qty:2}
    ]

product.forEach(function (arrayItem) {
        arrayItem.total = arrayItem.value * arrayItem.qty;
    });
console.log(product);

使用 .map 方法

let product =  [
    {omschrijving:"Brood", value:1, qty:3},
    {omschrijving:"Brocolli", value:0.99, qty:2},
    {omschrijving:"Krentenbollen", value:1.20, qty:4},
    {omschrijving:"Noten", value:2.99, qty:2}
    ]

product.map(pro => 
   {pro.total = pro.value * pro.qty;
   return pro;
   }
)
console.log(product);


推荐阅读