vue父子组件之间通讯方式

简介: vue父子组件之间通讯方式

在Vue中,父子组件之间传值通信有多种方法,可以通过props、$emit、provide/inject等方式实现。

  1. 使用props和$emit: 父组件可以通过props向子组件传递数据,子组件通过$emit触发自定义事件将数据传递给父组件。

父组件示例:

<template>
  <div>
    <child-component :message="message" @update-message="updateMessage"></child-component>
    <p>父组件消息:{{ message }}</p>
  </div>
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
  data() {
    return {
      message: 'Hello',
    };
  },
  components: {
    ChildComponent,
  },
  methods: {
    updateMessage(newMessage) {
      this.message = newMessage;
    },
  },
};
</script>

子组件示例:

<template>
  <div>
    <p>子组件消息:{{ message }}</p>
    <button @click="changeMessage">改变消息</button>
  </div>
</template>
<script>
export default {
  props: ['message'],
  methods: {
    changeMessage() {
      this.$emit('update-message', 'New message from child component');
    },
  },
};
</script>
  1. 使用$emit触发事件: 父组件可以通过$emit触发自定义事件,子组件通过监听该事件获取父组件传递的值。

父组件示例:

<template>
  <div>
    <child-component @custom-event="handleCustomEvent"></child-component>
    <p>父组件消息:{{ message }}</p>
  </div>
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
  data() {
    return {
      message: '',
    };
  },
  components: {
    ChildComponent,
  },
  methods: {
    handleCustomEvent(newMessage) {
      this.message = newMessage;
    },
  },
};
</script>

子组件示例:

<template>
  <div>
    <button @click="emitCustomEvent">传递消息</button>
  </div>
</template>
<script>
export default {
  methods: {
    emitCustomEvent() {
      this.$emit('custom-event', 'New message from child component');
    },
  },
};
</script>
  1. 使用provide/inject: 父组件可以通过provide提供数据,子组件通过inject注入获取父组件传递的数据。

父组件示例:

<template>
  <div>
    <child-component></child-component>
  </div>
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
  provide: {
    message: 'Hello',
  },
  components: {
    ChildComponent,
  },
};
</script>

子组件示例:

<template>
  <div>
    <p>子组件消息:{{ message }}</p>
  </div>
</template>
<script>
export default {
  inject: ['message'],
};
</script>

这些方法都可以实现父子组件之间的传值通信,根据具体的业务需求,选择合适的方法即可。

目录
相关文章
|
1天前
|
资源调度 JavaScript 前端开发
【vue】vue中的路由vue-router,vue-cli脚手架详细使用教程
【vue】vue中的路由vue-router,vue-cli脚手架详细使用教程
|
1天前
|
JavaScript 前端开发
vue组件化开发流程梳理,拿来即用
vue组件化开发流程梳理,拿来即用
|
1天前
|
JavaScript Go
Vue路由跳转及路由传参
Vue路由跳转及路由传参
|
2天前
|
JavaScript 前端开发 BI
采用前后端分离Vue,Ant-Design技术开发的(手麻系统成品源码)适用于三甲医院
开发环境 技术架构:前后端分离 开发语言:C#.net6.0 开发工具:vs2022,vscode 前端框架:Vue,Ant-Design 后端框架:百小僧开源框架 数 据 库:sqlserver2019
采用前后端分离Vue,Ant-Design技术开发的(手麻系统成品源码)适用于三甲医院
|
4天前
|
监控 JavaScript
Vue中的数据变化监控与响应——深入理解Watchers
Vue中的数据变化监控与响应——深入理解Watchers
|
JavaScript
Vue父子组件传值(porvide+inject实现组件通信)
如果我们需要把父组件的值传递给子组件,而且子组件可能存在层层嵌套,那么就可以使用provide+inject的方法来实现组件之间的通信
158 0
Vue父子组件传值(porvide+inject实现组件通信)
|
JavaScript 前端开发
前端-vue基础63-非父子组件传值
前端-vue基础63-非父子组件传值
70 0
前端-vue基础63-非父子组件传值
|
JavaScript
Vue父子组件传值通讯,超详细注释
Vue父子组件传值通讯,超详细注释
213 0