首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在VueJs中对对象数组中的唯一对象及其值进行分组

,可以使用computed属性和reduce方法来实现。

首先,我们需要在Vue实例的data中定义一个对象数组,例如:

代码语言:txt
复制
data() {
  return {
    items: [
      { id: 1, name: 'Apple', category: 'Fruit' },
      { id: 2, name: 'Banana', category: 'Fruit' },
      { id: 3, name: 'Carrot', category: 'Vegetable' },
      { id: 4, name: 'Tomato', category: 'Vegetable' },
      { id: 5, name: 'Orange', category: 'Fruit' },
    ]
  }
}

然后,我们可以使用computed属性来对对象数组进行分组,代码如下:

代码语言:txt
复制
computed: {
  groupedItems() {
    return this.items.reduce((result, item) => {
      const key = item.category;
      if (!result[key]) {
        result[key] = [];
      }
      result[key].push(item);
      return result;
    }, {});
  }
}

在上述代码中,我们使用reduce方法对items数组进行遍历,并根据category属性作为键来分组对象。如果分组中不存在该键,则创建一个空数组作为值,然后将当前对象item添加到对应的分组中。

最后,我们可以在模板中使用groupedItems来展示分组后的结果,例如:

代码语言:txt
复制
<template>
  <div>
    <div v-for="(group, key) in groupedItems" :key="key">
      <h2>{{ key }}</h2>
      <ul>
        <li v-for="item in group" :key="item.id">
          {{ item.name }}
        </li>
      </ul>
    </div>
  </div>
</template>

上述模板中,我们使用v-for指令遍历groupedItems对象,将每个分组的键和值展示出来,并使用嵌套的v-for指令遍历每个分组中的对象数组,将每个对象的name属性展示出来。

这样,我们就可以在VueJs中对对象数组中的唯一对象及其值进行分组了。

推荐的腾讯云相关产品:无

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 领券