在 Vue 中,emit 是一種自定義事件傳遞方式。當(dāng)我們需要在父子組件中傳遞參數(shù)時(shí),可以使用 emit 方法。 在 Vue 的官方文檔中,emit 的格式如下:
this.$emit('eventName', params);
其中,eventName 是我們自定義的事件名,params 是傳遞的參數(shù)。通過(guò) emit 方法傳遞參數(shù),我們可以實(shí)現(xiàn)父子組件之間的數(shù)據(jù)通訊。
在 Vue 中,我們可以在子組件中通過(guò)監(jiān)聽(tīng) emit 事件來(lái)獲取父組件傳遞過(guò)來(lái)的參數(shù)。具體來(lái)說(shuō),我們可以使用 v-on 指令來(lái)監(jiān)聽(tīng)自定義事件。在子組件中,我們可以這樣寫:
Vue.component('child-component', {
template: `
<div>
<h2>{{label}}</h2>
<button v-on:click="emitEvent">點(diǎn)擊我</button>
</div>
`,
props: ['label'],
methods: {
emitEvent: function () {
this.$emit('custom-event', 123);
}
}
})
在這個(gè)例子中,我們?cè)谧咏M件中定義了一個(gè) emit 方法。當(dāng)我們點(diǎn)擊按鈕時(shí),emit 方法會(huì)被觸發(fā),同時(shí)會(huì)傳遞參數(shù) 123 給父組件。
在父組件中,我們可以通過(guò) v-on 指令來(lái)監(jiān)聽(tīng)子組件的自定義事件。具體來(lái)說(shuō),我們可以這樣寫:
Vue.component('parent-component', {
template: `
<div>
<h1>{{title}}</h1>
<child-component :label="label" v-on:custom-event="onCustomEvent"></child-component>
</div>
`,
data: function () {
return {
title: '我是父組件',
label: '我是子組件的 label'
};
},
methods: {
onCustomEvent: function (params) {
console.log('我是父組件,我收到了子組件傳遞過(guò)來(lái)的參數(shù):', params);
}
}
})
在這個(gè)例子中,我們?cè)诟附M件中通過(guò) v-on 指令來(lái)監(jiān)聽(tīng)子組件的自定義事件。當(dāng)子組件觸發(fā)自定義事件時(shí),父組件中的 onCustomEvent 方法會(huì)被觸發(fā),同時(shí)會(huì)獲取到子組件傳遞過(guò)來(lái)的參數(shù)。
總結(jié)起來(lái),emit 是 Vue 中自定義事件的一種傳遞方式,我們可以通過(guò) $emit 來(lái)觸發(fā)自定義事件并傳遞參數(shù),也可以通過(guò) v-on 指令來(lái)監(jiān)聽(tīng)子組件的自定義事件并獲取參數(shù),從而實(shí)現(xiàn)父子組件之間的數(shù)據(jù)通訊。