Vue父組件調用子組件事件的兩種方法


首先我們要了解 $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事件,結果如下圖:


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM