vue 父组件调用子组件中的函数的两种方法
参考链接:vue 父组件调用子组件函数的两种方法https://www.jianshu.com/p/94c36323f7331.$on $emit的组合使用父组件调用子组件的函数,所以父组件中使用emit("函数名",传递的参数);子组件中监听此函数使用emit("函数名",传递的参数);子组件中监听此函数使用emit("函数名",传递的参数);子组件中监听此函数使用on(“函数名”,res=&g
参考链接: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>
更多推荐
所有评论(0)