Vue 2 - 计算输入的行总数

时间:2017-07-31 21:30:50

标签: vuejs2

我有一张数量和动态的动态表格。价格输入,我使用计算属性来计算每一行的总和。 现在我需要找到一种方法来计算grandtotal(所有小计的总和)。

HTML:

   <tr v-for="(item, index) in items">
      <td><input v-model.number="item.qty" size="10"></td>
      <td><input v-model.number="item.price" size="10"></td>
      <td><input v-model.number="subtotalRow[index]" readonly size="10"></td>
      <td><button @click="addRow(index)">+</button></td>
      <td><button @click="removeRow(index)">-</button></td>
   </tr>
   <tr>
      <td>Total: {{total}}</td>
   </tr>

使用Javascript:

computed: {
    subtotalRow() {
      return this.items.map((item) => {
        return Number(item.qty * item.price)
      });
    },
    // the index part is confusing me
    //
    // total() {
    //  return this.items.reduce((total, ?) => {
    //    return total + ?;
    //  }, 0);
    //}
},

我提供了一个小小的小提琴来清楚地说明问题。

https://jsfiddle.net/h5swdfv5/

我希望一些指导可以帮助我。 提前谢谢

1 个答案:

答案 0 :(得分:7)

{{1}}

工作小提琴:https://jsfiddle.net/h5swdfv5/1/