cari

Rumah  >  Soal Jawab  >  teks badan

Tunjukkan prop yang digunakan dalam fungsi penapis - axios, vue3

Cara memaparkan prop dalam FilteredProducts apabila menggunakan axios untuk mendapatkan data. Saya telah lulus props seperti yang ditunjukkan di bawah.

export default {
  data() {
    return {
      filteredProducts: [],
    };
  },
  mounted() {
 axios
 .get('/src/stores/sneakers.json')
 .then(response => { const products = response.data
  this.filteredProducts = products.filter(product => product.name.includes('Nike'))
})
  },
  computed: {
        resultCount () {
            return Object.keys(this.filteredProducts).length 
        },
    },
  props: {
    brand: {
      type: Object,
    },
  },

Saya ingin menggantikan "Nike" dengan nama jenama yang diluluskan. Terima kasih banyak-banyak

P粉439804514P粉439804514502 hari yang lalu595

membalas semua(2)saya akan balas

  • P粉872101673

    P粉8721016732023-09-09 09:13:18

    Pilih produk bernama "Nike" dan masukkan ke dalam filteredProducts. Selepas itu anda boleh menukar nama menggunakan harta yang dikira dan menggunakannya dalam templat.

    <template>
      <div 
        v-for="(item, i) in nikeProducts"
        :key="i"
      >
      </div>
    </template>
    
    <script>
    export default {
      props: {
        brand: {
          type: Object
        }
      }
      data() {
        return {
          filteredProducts: [],
        };
      },
      mounted() {
        axios
          .get('/src/stores/sneakers.json')
          .then(response => { 
              const products = response.data
              this.filteredProducts = products.filter(product => product.name.include('Nike'));
          })
      },
      computed: {
        nikeProducts() {
          return this.filteredProducts.map(product => product.name = this.brand.name)
        }
      }
    }
    </script>

    balas
    0
  • P粉529245050

    P粉5292450502023-09-09 09:09:06

    export default {
                  data() {
                    return {
                      products: [],
                    };
                  },
                  mounted() {
                       this.getSneakers();
                  },
                  methods: {
                     getSneakers() {
                     axios
                      .get('/src/stores/sneakers.json')
                       .then(response => { 
                      this.products = response.data ?? [];
                          })
                      }
                   },
                  computed: {
                        resultCount () {
                            return this.filteredProducts?.length ?? 0
                        },
                        brandName() {
                            return this.brand?.name ?? "";
                        },
                        filteredProducts () {
                            return this.products?.filter(
            product => product.name?.toLowerCase()?.includes(this.brandName.toLowerCase())
                       )
                        },
                    },
                  props: {
                    brand: {
                      type: Object,
                    },
                  },
              }

    balas
    0
  • Batalbalas