vue 双向绑定问题 emit无效

2017-03-15 11:43:59vue.js问题

父组件变量传给子组件,子组件修改后回传给父组件,无法修改

<div id="app">
    <navbar :list="nav" :current="current"></navbar>
</div>

<template id="navbar">
    <div v-for="(item,index) in list" @click="setCurrent(index)">
        <div :>{{item.name}}</div>
    </div>
</template>

<script>
    new Vue({
        el: '#app',
        data: {
            nav: [{
                name: '标题',
                type: 'title'
            }, {
                name: '颜色',
                type: 'color'
            }],
            current: 0
        },
        methods: {
            onCurrent: function(index) {
                console.log(index);
                this.current = index;
            }
        },
        components: {
            navbar: {
                props: ['list', 'current'],
                template: '#navbar',
                methods: {
                    setCurrent: function(index) {
                        this.$emit('on-current', index);
                    }
                }
            }
        }
    });
    </script>

子组件中setCurrent正常执行,父组件onCurrent却没有反应,而且父组件的current变量未发生变化;

有哪位大大帮看看什么情况

热门评论:

  • vczhan vczhan 2017-3-15 12:10 回复:

    <navbar :list="nav" :current="current" @on-current="onCurrent"></navbar>

网友回答:

在你代码中没有看到你使用到onCurrent这个方法

<div id="app">
    <navbar :list="nav" :current="current" @on-current="onCurrent"></navbar>
</div>

  • 我不知道啊 我不知道啊 2017-3-15 12:12 回复:

    在navbar上添加 @on-current="onCurrent"

    • jsoncode jsoncode 2017-3-15 12:18 回复:我不知道啊
      回去试试

  • 西安小哥 西安小哥 2017-3-15 5:09 回复:

    clipboard.png
    this.$on('on-current', function (msg) {
    console.log(msg)
    })