Как обработать массив Vuex в Vue. js - PullRequest
0 голосов
/ 09 апреля 2020

Я новый веб-разработчик. Мне нужна помощь, чтобы получить все заголовки из всех объектов в массиве. Я получаю массив продуктов из запроса топора ios. На следующем шаге мне нужно обработать этот массив в компоненте Vue и записать одно значение в данные. Далее мне нужно отобразить это значение данных в настройках мультиселектора.

Вот код топора ios:

async getOrders(ctx, data)
{
    return new Promise((resolve, reject) => {
        axios({
            url: '/orders',
            data: data,
            method: 'GET'
        })
            .then((resp) => {
                ctx.commit('setOrders', resp.data.orders)
                ctx.commit('setUsers', resp.data.users)
                ctx.commit('setProducts', resp.data.products)
                ctx.commit('updatePagination', resp.data.pagination)
                resolve(resp)
            })
            .catch((error) => {
                console.log(error)
                reject(error)
            })
    })
},

Это мой массив товаров, записанных в магазине Vuex

0: {id: 6, category_id: 2, title: "Test", brand: "Тест", serial_number: "2165412315864",…}

1: {id: 7, category_id: 3, title: "Климат", brand: "Климат", serial_number: "2165412315864",…}

2: {id: 8, category_id: 5, title: "New", brand: "New", serial_number: "2165412315864",…}

Это мой код для обработки этого массива

computed:{
        ...mapGetters('order', ['users', 'products',  'orders']),
    },
    methods:{
        getProducts(products)
        {

            const arr = products.map(c => c.title)
            console.log('titles: ', arr); //Debug
            this.options = arr
        }

    },

А вот код для множественного выбора

<multiselect v-model="formData.product" :options="options" :value="values" :multiple="true" :close-on-select="false" :clear-on-select="false" :preserve-search="true" placeholder="Pick some" label="name" track-by="name" :preselect-first="true">
                                            <template slot="selection" slot-scope="{ values, search, isOpen }"><span class="multiselect__single" v-if="values.length &amp;&amp; !isOpen">{{ values.length }} options selected</span></template>
                                        </multiselect>



mounted() {
        this.getProducts();
    },

1 Ответ

0 голосов
/ 09 апреля 2020

Похоже, вы не отправляете свои аргументы, просто набрав this.getProducts(). Вам не нужно, просто напишите this. перед вычисленным значением внутри метода.

methods: {
    getProducts () {
        const arr = this.products.map(c => c.title)
        this.options = arr
    }
}
...