如何循环 Vuex 商店中的项目
P粉513318114
P粉513318114 2023-09-11 23:38:31
0
1
615

这是我在 Vue 开发工具中的商店:

这是我的 Vue 组件:

<template>
  <div>
      <div
        v-for="product in allProducts"
        :key="product._id"
      >
        {{ product.brand }}
      </div>
  </div>
</template>
<script>
import { mapGetters } from "vuex";
export default {
  data() {
    return{
      allProducts:[],
    }
  },
  computed: {
    ...mapGetters(["allProducts"])
  },
  mounted() {
    this.$store.dispatch("getProducts");
  }
};
</script>

如果我使用这个:

{{allProducts}}

我得到了所有产品。

但是当尝试用这个循环时:

<div
        v-for="product in allProducts"
        :key="product._id"
      >
        {{ product.brand }}
      </div>

不显示。

请问我该怎么办?

P粉513318114
P粉513318114

全部回复(1)
P粉536909186

allProducts 是具有属性 products 的对象,因此为了循环产品,请尝试 product in allProducts.products

const app = Vue.createApp({
  data() {
    return {
      allProducts: {
        products: [
          {brand: 'aaa'}, {brand: 'bbb'}
        ]
      }
    };
  },
})
app.mount('#demo')
<script src="https://unpkg.com/vue@3/dist/vue.global.prod.js"></script>
<div id="demo">
  <div v-for="product in allProducts.products">
    {{ product.brand }}
  </div>
</div>
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板