首页 文章

vue.js select / dropdown selected item vm binding not working(bootstrap-vue)

提问于
浏览
2

我正在尝试创建一个简单的vue,将所选项目从选择/下拉列表绑定到vm中的属性 . 当使用也在视图模型中的选项集合时,我无法找到一个清晰而简单的示例,说明它是如何关闭的 .

<template>
    <div>
        <h1>Select box</h1>
        <b-dropdown id="ddCommodity"
                    name="ddCommodity"
                    v-model="ddTestVm.ddTestSelectedOption"
                    text="Select Item"
                    variant="primary"
                    class="m-md-2" v-on:change="changeItem">
            <b-dropdown-item disabled value="0">Select an Item</b-dropdown-item>
            <b-dropdown-item v-for="option in ddTestVm.options":selected="option.value == 'LME/ST_TNI_ALL'":value="option.value">{{option.text}}</b-dropdown-item>           
        </b-dropdown> <span>Selected: {{ ddTestVm.ddTestSelectedOption }}</span>
 </div>
</template>


<script>
    export default {
        components: {

        },
        data() {
            return {
                someOtherProperty: null,
                ddTestVm: {
                    originalValue: [],
                    ddTestSelectedOption: "Value1",
                    disabled: false,
                    readonly: false,
                    visible: true,
                    color: "",
                    options: [
                        {
                            "value": "Value1",
                            "text": "Value1Text"
                        },
                        {
                            "value": "Value2",
                            "text": "Value2Text"
                        },
                        {
                            "value": "Value3",
                            "text": "Value3Text"
                        }
                    ]
                }
            }
        },        
        methods: {
            changeItem: async function () {
            //grab some remote data
                try {
                    let response = await this.$http.get('https://www.example.com/api/' + this.ddTestVm.ddTestSelectedOption + '.json');
                    console.log(response.data);
                    this.someOtherProperty = response.data;
                } catch (error) {
                    console.log(error)
                }
            }
        },
        watch: {

        },
        async created() {

        }
    }
</script>

<style>
</style>

无论我尝试过什么,我都无法在下拉列表中获取所选值以更改vm的ddTestSelectedOption属性 .

1 回答

  • 7

    b-dropdownbootstrap-vue 中不支持 v-model . 如the documentation所述:

    下拉菜单是可切换的上下文叠加,用于以下拉菜单格式显示链接和操作列表 .

    换句话说, b-dropdown 本质上是用于显示菜单或类似选项集的UI组件 .

    我希望你想要的是b-form-select .

    也就是说,您可以为设置值的选项添加单击处理程序 .

    <b-dropdown-item v-for="option in ddTestVm.options" 
                        :key="option.value" 
                        :value="option.value"
                        @click="ddTestVm.ddTestSelectedOption = option.value">
    

    这是working example .

相关问题