首先我們要了解 $on 和 $emit:
vm.$on( event, callback ):監聽當前實例上的自定義事件。事件可以由vm.$emit觸發。回調函數會接收所有傳入事件觸發函數的額外參數。
vm.$emit( event, […args] ):觸發當前實例上的事件。附加參數都會傳給監聽器回調。
-
1. 方法一:$emit、$on 方式
-
2. 方法二:通過ref直接調用子組件方法
父組件中:
<template>
<div>
<div @click="click">點擊父組件</div>
<child ref="child"/ >
</div>
</template>
<script>
import child from "./child";
export default {
methods: {
click() {
this.$refs.child.$emit('childMethod','發送給方法一的數據') // 方法1:觸發監聽事件
this.$refs.child.callMethod() // 方法2:直接調用
},
},
components: {
child,
}
}
</script>
子組件中:
<template>
<div>子組件</div>
</template>
<script>
export default {
mounted() {
this.monitoring() // 注冊監聽事件
},
methods: {
monitoring() { // 監聽事件
this.$on('childMethod', (res) => {
console.log('方法1:觸發監聽事件監聽成功')
console.log(res)
})
},
callMethod() {
console.log('方法2:直接調用調用成功')
},
}
}
</script>
觸發父組件的click事件,結果如下圖: