详解Vue3子组件向父组件传递消息
父子组件之间的通信:props与emit
通常提到props,都会想到的是父组件给子组件传值;提到emit为子组件向父组件发送消息,但其实,props也可以使子组件向父组件传递消息
方式为在父组件中通过为子组件绑定属性,子组件接收;但其实,我们只需要父组件向子组件传递一个事件,使子组件调用该事件来获取子组件的消息
常规使用
<!-- 子组件A -->
<template>
<div style="color:coral">
我是B的子组件A
</div>
</template>
<script setup>
import { onMounted } from "vue";
const props = defineProps({
msg: String
})
onMounted(() => {
console.log('我是A,我接收到B给我传递的消息', props);
})
</script><!-- 父组件B -->
<template>
<div>
<h1>我是父组件B,下面是我的子组件A</h1>
<A msg="我是父组件B,我现在向A组件传递消息"></A>
</div>
</template>
<script setup>
import A from "../components/A.vue"
</script>
子组件向父组件传递消息
<!-- 子组件A -->
<template>
<div style="background:gainsboro">
<h3 style="color:coral">我是B的子组件A</h3>
<button @click="send">向B发消息</button>
</div>
</template>
<script setup>
import { onMounted } from "vue";
const props = defineProps({
msg: String,
myFn: Function
})
onMounted(() => {
console.log('我是红薯我是红薯,收到收到', props);
})
const send = () => {
props.myFn('我是A,我调用B的事件向它发送此消息:嘿~土豆')
}
</script><!-- 父组件B -->
<template>
<div>
<p>我是父组件B,我传递给A组价的事件,A调用后我可以接收到:
<span style="color:darkorange">{{state.childMsg}}</span>
</p>
<h1>我是父组件B,下面是我的子组件A</h1>
<A
msg="我是土豆我是土豆,收到请回答"
:myFn="state.fn"
></A>
</div>
</template>
<script setup>
import { reactive } from "vue";
import A from "../components/A.vue"
const state = reactive({
childMsg: '暂无消息',
fn: (data) => {
state.childMsg = data
}
})
</script>
当子组件A点击“向B发送消息” 调用了这个myFn的函数,并且传递参数,父组件B中就可以收到A传递的参数,此时就完成了子组件行父组件传递消息

与emit的区别:定义和调用的不同
props方式:父组件为子组件绑定一个属性,将函数赋值给该属性,子组件通过props接收,调用此事件,传递消息。emit方式:父组件需要在子组件标签中注册一个事件,子组件通过emit调用此事件,传递消息。


到此这篇关于详解Vue3子组件向父组件传递消息的文章就介绍到这了,更多相关Vue3子组件向父组件传递消息内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决vue打包后刷新页面报错:Unexpected token <
这篇文章主要介绍了解决vue打包后刷新页面报错:Unexpected token <相关知识点,需要的朋友们参考下。2019-08-08
vue.js开发实现全局调用的MessageBox组件实例代码
最近学习了Vue.js,感觉组件这个地方知识点挺多的,而且很重要,所以决定记录下,下面这篇文章主要给大家介绍了关于利用vue.js开发实现全局调用的MessageBox组件的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。2017-11-11
Vue中使用 Aplayer 和 Metingjs 添加音乐插件的方式
这篇文章主要介绍了Vue中使用 Aplayer 和 Metingjs 添加音乐插件,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2022-08-08
解决Vue运算符报错:Syntax Error: Unexpected token问题
这篇文章主要介绍了解决Vue运算符报错:Syntax Error: Unexpected token问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-01-01


最新评论