可以't从子组件获取要在父组件上执行的方法

Can't get method to execute on parent component from child component

本文关键字:组件 执行 方法 获取 可以      更新时间:2023-09-26

当单击父组件中的一个子组件中的按钮时,我正试图在父组件上执行一个方法。我在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"不会,总数也不会改变。你知道我做错了什么吗?提前感谢!

您的方法使用lambda表示法,这给了它们错误的this。如果您使用function,它将起作用。

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'
  }
});
<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>

count组件的total属性使用双向.sync绑定类型修饰符,以便在父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>