参考链接:vue 父组件调用子组件函数的两种方法https://www.jianshu.com/p/94c36323f733

1.$on $emit的组合使用

父组件调用子组件的函数,所以父组件中使用 e m i t ( " 函 数 名 " , 传 递 的 参 数 ) ; 子 组 件 中 监 听 此 函 数 使 用 emit("函数名",传递的参数);子组件中监听此函数使用 emit("")使on(“函数名”,res=>{执行函数});res即为父组件传递给子组件的参数。

2.直接调用

举例如下:

父组件

<template>
    <div>
        <div @click="click">点击父组件</div>
        <child ref="child"></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>
Logo

基于 Vue 的企业级 UI 组件库和中后台系统解决方案,为数万开发者服务。

更多推荐