在Vue 2中更改时传递范围输入值

时间:2017-03-17 14:26:38

标签: javascript events vue.js vuejs2

在Vue 2中:我有一个App组件,其中有一个Slider组件:

App.vue

<template>
    <div>
        <Slider :foo="store.foo"></Slider>
    </div>
</template>

<script>
    import store from './components/store.js';
    import Slider from './components/Slider.vue';

    export default {
        name: 'app',

        components: { Slider },

        data() { 
            return {
                store: store
            }
        },

        methods: {
            changeFoo(foo) {
                console.log('change!', foo);
            },
        },
    }
</script>

Slider.vue

<template>
    <div>
        <input type="range" min="1" max="100" step="1" @change="changeFoo" />
    </div>
</template>

<script>
    export default {
        props: ['foo'],
        methods: {
            changeFoo() {
                this.$emit('changeFoo', foo);
            }
        }
    }
</script>

问题是滑块的值未在emit的{​​{1}}语句中传递。我明白为什么 - 但我不确定如何解决它。我试过了:

Slider.vue

v-model="foo" 元素中,但Vue发出警告,我不允许改变道具。

1 个答案:

答案 0 :(得分:2)

而不是使用prop为slider创建一个新的数据变量并在emit中传递这个变量,如下所示:

<template>
    <div>
        <input v-model="sliderVal" type="range" min="1" max="100" step="1" @change="changeFoo" />
    </div>
</template>

<script>
    export default {
        props: ['foo'],
        data: function() {
           return {
              sliderVal: ""
           }
        }
        methods: {
            changeFoo() {
                this.$emit('changeFoo', this.sliderVal);
            }
        }
    }
</script>

同样在 App.vue 中,你必须像这样列出这个发布的事件:

<template>
    <div>
        <Slider :foo="store.foo" @change-foo="changeFoo"></Slider>
    </div>
</template>