无法从子组件获取在父组件上执行的方法

时间:2016-08-27 20:23:20

标签: javascript vue.js vue-component

当我点击其中一个子组件中的按钮时,我正在尝试获取一个在父组件上执行的方法。我在Webpack中使用单个文件组件。这是子组件的代码:

<template>
  <button v-on:click="add">Click</button>
</template>

<script>
export default {
  methods: {
    add: () => {
      console.log('foo')
      this.$dispatch('addClick')
    }
  }
}
</script>

父母的代码:

<template>
  <div id="app">
    <count :total="total"></count>
    <click></click>
  </div>
</template>

<script>
import count from './components/count.vue'
import click from './components/click.vue'

export default {
  components: {
    count,
    click
  },
  data: () => {
    return {
      total: 0
    }
  },
  methods: {
    addToTotal: () => {
      console.log('bar')
      this.total += 1
    }
  },
  events: {
    addClick: 'addToTotal'
  }
}
</script>

count组件只是一个显示total变量的h1元素。当我单击按钮时,“foo”会记录到控制台,但“bar”不会记录,并且总计不会更改。关于我做错了什么的任何想法?提前谢谢!

2 个答案:

答案 0 :(得分:1)

您正在为方法使用lambda表示法,这会给他们错误的this。如果您使用function代替它,它将起作用。

&#13;
&#13;
Vue.component('click', {
  template: '#clicker',
  methods: {
    add: function() {
      console.log('foo')
      this.$dispatch('addClick')
    }
  }

})

new Vue({
  el: '#app',
  data: () => {
    return {
      total: 0
    }
  },
  methods: {
    addToTotal: function () {
      console.log('bar')
      this.total += 1
    }
  },
  events: {
    addClick: 'addToTotal'
  }
});
&#13;
<script src="//cdnjs.cloudflare.com/ajax/libs/vue/1.0.26/vue.min.js"></script>
<template id="clicker">
  <button v-on:click="add">Click</button>
</template>

<div id="app">
  <count :total="total"></count>
  <click></click>
  {{total}}
</div>
&#13;
&#13;
&#13;

答案 1 :(得分:0)

.sync组件的total属性上使用双向count绑定类型修饰符,以便在更改父total值时更新该值。这是一个例子:

Vue.component('click', {
    template: '<button v-on:click="add">Click</button>',
    methods: {
        add: function () {
            this.$dispatch('addClick');
        }
    }
});

Vue.component('count', {
    template: '<h1 v-text="total"></h1>',
    props: {
        total: {
            type: Number,
            twoWay: true
        }
    }
});

new Vue({
    el: '#app',
    data: {
        total: 1
    },
    methods: {
        addTotal: function () {
            this.total++;
        }
    },
    events: {
        addClick: 'addTotal'
    }
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/1.0.25/vue.min.js"></script>

<div id="app">
    <count :total.sync="total"></count>
    <click></click>
</div>