Search code examples
javascriptjqueryarraysvue.jsvue-resource

How do I get a plain array back from vuejs with a component?


I am using a call to my database to retrieve some results and pushing them onto an array. However when I console.log(this.activeBeers) I don't get an array back but instead an object. How can I get a plain array back instead of a object?

Vue.component('beers', {
    template: '#beers-template',

    data: function() {
        return {
            activeBeers: []
        }
    },

    ready: function() {
        function getActiveBeers(array, ajax) {
            ajax.get('/getbeers/' + $('input#bar-id').val()).then(function (response) {
                $.each(response.data, function(key, value) {
                    array.push(value.id);
                });
            }, function (response) {
                console.log('error getting beers from the pivot table');
            });

            return array;
        }

        console.log(this.activeBeers = getActiveBeers(this.activeBeers, this.$http));
    },

    props: ['beers']
});

Solution

  • The other answer is correct, getActiveBeers sends an HTTP request and then immediately returns the array, it doesn't wait for the ajax request to come back. You need to handle the updating of activeBeers in the success function of the ajax request. You can use the .bind() function to make sure that this in your success function refers to the Vue component, that way you can just push the ids directly into your activeBeers array.

    Vue.component('beers', {
        template: '#beers-template',
    
        data: function() {
            return {
                activeBeers: []
            }
        },
    
        ready: function() {
            this.getActiveBeers();
        },
    
        methods: {
            getActiveBeers: function(){
    
                this.$http.get('/getbeers/' + $('input#bar-id').val()).then(function (response) {
    
                    $.each(response.data, function(key, value) {
                        this.activeBeers.push(value.id);
                    }.bind(this));
    
                    console.log(this.activeBeers);
    
                }.bind(this), function (response) {
    
                    console.log('error getting beers from the pivot table');
    
                });
    
            }
        }
    
        props: ['beers']
    
    });