@Nurshat

Почему не работает v-for в vue?

Html
<div id="app">
    <records></records>
</div>


JS
Vue.component('records', {
    template: ' <div>{{orders}}</div> <div><div v-for="order in orders"> {{order.id}}</div></div>',

    data: function() {
        return{
            orders: [{id: 1}, {id: 2}, {id: 3}]
        }
    },

    created: function () {
        this.getOrders();
    },

    methods: {
        getOrders: function () {
            var vm = this;
            axiosInst.get('/records')
                .then(function (response) {
                    //vm.$set('ordersList', response.data);

                    vm.orders = response.data.slice();
                    console.log(vm.orders);
                    console.log(response.data);
                })
                .catch(function (error) {
                    console.log(error);
                });
        },
    }
})

var app = new Vue({
    el: '#app',
    data: {
        message: 'Hello Vue!'
    }
})


Столкнулся с такой проблемой, не срабатывает v-for, хотя без цикла объекты без проблем выводятся.
Помогите пожалуйста разобраться.
  • Вопрос задан
  • 930 просмотров
Решения вопроса 2
kulakoff
@kulakoff Куратор тега Vue.js
Vue.js developing
Возможно из-за того, что у вас шаблон компонента records имеет больше одного корневого элемента.
Ответ написан
@fomenko_alexandr
Да, всё правильно ответили
Шаблон должен иметь только один родительский элемент
В вашем случае нужно обернуть всё в один див:
template: '<div><div>{{orders}}</div> <div><div v-for="order in orders"> {{order.id}}</div></div></div>',
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы