1. 程式人生 > >vue---vue中如何自定義事件?子元件事件如何向上觸發父元件事件?

vue---vue中如何自定義事件?子元件事件如何向上觸發父元件事件?

vue的自定義事件非常有趣,大意為子元件使用了一個事件,比如click然後產生了一個效果,這樣的效果便可以為自定義事件了。然後將這樣的效果命名放入父元件中,當做一個事件來觸發,每當這樣的效果發生一次時,這樣父元件的事件也被觸發了,即可以產生另一種效果,這樣可以加強這兩個效果的緊密聯絡,並且這樣有趣又好用的方式也可以用在自己想要的地方。自定義事件的強大算是初步體會到了。

例子:

<div id="counter-event-example">
<p>{{ total }}</p>
<button-counter v-on:increment="incrementTotal"
></button-counter> <button-counter v-on:increment="incrementTotal"></button-counter> </div> Vue.component('button-counter', {   template: '<button v-on:click="increment">{{ counter }}</button>',   //click的 觸發會向上觸發自定義事件incremnet,從而在函式incrementTotal中改變total的大小   data: function
() {
    return {       counter: 0     }   },   methods: {     increment: function () {       this.counter += 1       this.$emit('increment')     }   }, }) new Vue({   el: '#counter-event-example',   data: {     total: 0   },   methods: {     incrementTotal: function () {       this.total += 1     }   } })

轉載