vue3 + ts,对象里的属性求和

已知data1如下

data1 = [
            { A: 1, B: 2, C: 3, D: 4 },
            { A: 2, B: 1, C: 1, D: 3 },
        ]

得到data2如下:

data2 = [
            {
                name: 'A',
                value: data1[0].A + data1[1].A + data1[2].A
            },
            {
                name: 'B',
                value: data1[0].B + data1[1].B + data1[2].B
            }
        ]

实现如下:

data1是一个数组,每个对象都有键名 A、B、C 和 D。使用 reduce 方法计算了键名 A 和 B 的总和,并将结果存储在 data2 数组中的相应对象中的 value 字段中

<script lang="ts">
import { defineComponent } from 'vue';

interface DataItem {
  A: number;
  B: number;
  C: number;
  D: number;
}

export default defineComponent({
  data() {
    const data1: DataItem[] = [
      { A: 1, B: 2, C: 3, D: 4 },
      { A: 2, B: 1, C: 1, D: 3 },
    ];
    // 计算键名 A 的总和
    const sumA = data1.reduce((acc, obj) => acc + obj.A, 0); 
    // 计算键名 B 的总和
    const sumB = data1.reduce((acc, obj) => acc + obj.B, 0); 

    const data2 = [
      { name: 'A', value: sumA },
      { name: 'B', value: sumB },
    ];

    return {
      data2,
    };
  },
});
</script>

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值