如何在另一个Vue组件中使用select2组件

时间:2019-01-21 15:53:03

标签: javascript laravel vue.js vuejs2 vue-component

我想要一个select2组件 在另一个组件中使用它。我已经导入了它,但无法使其正常工作。 我有app.vue组件和select2.vue组件。

<template>   
     <select2 :options="this.options" v-model="selected">
          <option disabled value="0">Select one</option>
    </select2>
</template>
 <script>
    import select2 from 'select2'

    export default {
    name: 'app',
    data(){
            return{
            options : [
                    { id: 1, text: 'Hello' },
                    { id: 2, text: 'World' }
                ],
                selected: 1,
            }
    },
    components: {
       'select2': select2,
     }
    }
    </script>

我有这样的select2组件:

<script>
    Vue.component('select2', {
        props: ['options', 'value'],
        template: '#select2-template',
        mounted: function () {
            var vm = this
            $(this.$el)
            // init select2
                .select2({ data: this.options })
                .val(this.value)
                .trigger('change')
                // emit event on change.
                .on('change', function () {
                    vm.$emit('input', this.value)
                })
        },
        watch: {
            value: function (value) {
                // update value
                $(this.$el)
                    .val(value)
                    .trigger('change')
            },
            options: function (options) {
                // update options
                $(this.$el).empty().select2({ data: options })
            }
        },
        destroyed: function () {
            $(this.$el).off().select2('destroy')
        }
    })

</script>

和类似这样的html代码:

我收到这样的错误:

[Vue warn]: Error in render: "TypeError: Cannot read property 'getAttribute' of undefined"

我是Vuejs的新手。我不明白是不是出错了。请帮我。谢谢

0 个答案:

没有答案