详解Vue3子组件向父组件传递消息

 更新时间:2023年07月11日 11:27:42   作者:椿☽  
这篇文章主要介绍了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状态管理工具Pinia的安装与使用教程

    Vue状态管理工具Pinia的安装与使用教程

    这篇文章主要介绍了Vue状态管理工具Pinia的安装与使用,一步一步学习如何将pinia运用到项目实战中去,文中有详细的安装教程和使用方法,并通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-03-03
  • 详解uniapp的生命周期

    详解uniapp的生命周期

    这篇文章主要介绍了uniapp的生命周期,应用生命周期是指应用程序从启动到关闭的整个过程,包括应用程序的启动、前后台切换、退出等,需要的朋友可以参考下
    2023-04-04
  • vue2更改data里的变量不生效时,深层更改data里的变量问题

    vue2更改data里的变量不生效时,深层更改data里的变量问题

    这篇文章主要介绍了vue2更改data里的变量不生效时,深层更改data里的变量问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03
  • Vue组件之间的通信方式详细讲解

    Vue组件之间的通信方式详细讲解

    对于vue来说,组件之间的消息传递是非常重要的,用vue可以是要组件复用的,而组件实例的作用域是相互独立,这意味着不同组件之间的数据无法互相引用,一般来说,组件之间可以有几种关系,下面是我对组件之间消息传递的常用方式的总结
    2022-08-08
  • Vue 页面状态保持页面间数据传输的一种方法(推荐)

    Vue 页面状态保持页面间数据传输的一种方法(推荐)

    vue router给我们提供了两种页面间传递参数的方式,一种是动态路由匹配,一种是编程式导航,接下来通过本文给大家介绍Vue 页面状态保持页面间数据传输的一种方法,需要的朋友可以参考下
    2018-11-11
  • Vue warn:Property "state" was accessed during render解决

    Vue warn:Property "state" was accessed during

    这篇文章主要为大家介绍了Vue warn:Property "state" was accessed during render的报错解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • vue列表自动滚动实例

    vue列表自动滚动实例

    这篇文章主要介绍了vue列表自动滚动实例代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • 使用vue2.0创建的项目的步骤方法

    使用vue2.0创建的项目的步骤方法

    这篇文章主要介绍了使用vue2.0创建的项目的步骤方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09
  • 关于应用UI组件的移动端适配方式

    关于应用UI组件的移动端适配方式

    这篇文章主要介绍了关于应用UI组件的移动端适配方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-09-09
  • Vue瀑布流插件的使用示例

    Vue瀑布流插件的使用示例

    这篇文章主要介绍了Vue瀑布流插件的使用示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-09-09

最新评论