【vue2--组件通信】

本文详细介绍了Vue.js中组件间的通信机制,包括父子组件的props和$emit方法,以及非父子组件间的eventbus和provide/inject策略。通过实例展示了如何在不同场景下实现数据的传递和共享。
摘要由CSDN通过智能技术生成

提示:组件通信


什么是组件通信

组件通信,就是组件与组件之间的数据传递
想用其他组件的数据–>组件通信


一、父子通信

1.父组件通过props将数据传递给子组件
2.子组件利用$emit通知父组件修改更新

1.步骤

(1)父传子

父组件通过props将数据传递给子组件

  1. 给子组件以添加属性的方式传值
  2. 子组件内部通过props接收
  3. 子组件将接收的数据在模板中直接使用
(2)子传父

子组件利用$emit通知父组件,进行修改更新

  1. $emit触发事件,给父组件发送消息通知
  2. 父组件监听事件
  3. 父组件提供处理函数,形参中获取参数

二、非父子通信

1.event bus 事件总线
2.provide & inject

1.event bus 事件总线

创建一个都能访问到的事件总线(空的Vue实例)

步骤

  1. 在src文件夹中创建新文件夹utils,在文件夹utils创建EventBus.js文件
    代码如下:
import Vue from 'vue'
const Bus = new Vue()
export default Bus
  1. 在要使用的组件中导入EventBus.js,不在APP.vue和Main.js中导入
  2. 信息接收方,用Bus.$on()监听Bus实例的事件,并接收数据
    代码如下:
<template>
  <div class="one">
    <span>今天天气怎么样?</span>
    <div>{{ msgIfon }}</div>
  </div>
</template>
<script>
import Bus from '../untils/EventBus.js'
export default {
  created() {
    Bus.$on('send', (msg) => {
      this.msgIfon = msg
    })    
  },
  data() {
        return {
        msgIfon:''
      }
    }
}
</script>
  1. 信息发送方,用Bus.$emit()触发Bus实例的事件

代码如下:

<template>
  <div class="two">我是发布方
    <button @click="sendMsg">发送通知</button>
  </div>
</template>
<script>
import Bus from '../untils/EventBus.js'
export default {
  methods: {
    sendMsg() {
    Bus.$emit('send','晴转多云')
  }
}
}
</script>

2.provide & inject

跨层级共享数据----子孙后代
复杂类型(响应式,推荐)
简单数据类型 (非响应式)
共享的时候,通常把它包成一个对象,以复杂类型的方式去共享

步骤

  1. 父组件只需用provide()提供数据,不需要给子组件绑定属性
    代码如下:
<template>
  <div id="app">我是父组件App.vue
    <SonA></SonA>
    <SonB></SonB>
  </div>
</template>

<script>
import SonA from './components/SonA.vue'
import SonB from './components/SonB.vue'
export default {
  components: {
    SonA,
    SonB
  },
  provide() {
    return {
      today: this.today,
      obj:this.todoList
    }
  },
  data() {
    return {
      today: ['周六'],
      todoList:['吃饭','睡觉','玩游戏','打扫卫生']
  }
}
}
</script>

在这里插入图片描述

  1. 子孙后代组件,用inject接收数据
    代码如下:

孙子组件GrandSon.vue

<template>
  <div class="grandson">我是GrandSon组件--{{ today }}--要做--{{ obj }}</div>
</template>
<script>
export default {
inject:['today','obj']
}
</script>
<style scoped>
  .grandson{
    width: 100px;
    height: 50px;
    font-size: 10px;
    margin: 15px;
    border: 1px solid #000;
  }
</style>

子组件SonA.vue

<template>
  <div class="son1">我是SonA组件--未用inject接收值
    <GrandSon></GrandSon>
  </div>
</template>
<script>
import GrandSon from './GrandSon.vue'
export default {
  components: {
  GrandSon
  }
}
</script>
<style scoped>
.son1 {
  width: 150px;
  height: 100px;
  border: 1px solid red;
  margin: 20px;
}

</style>

子组件SonB.vue

<template>
  <div class="son2">我是SonB组件-今天:{{ today }}--要做:{{ obj }}</div>
</template>
<script>
export default {
inject:['today','obj']
}
</script>
<style scoped>
  div{
    width: 150px;
    height: 100px;
    border: 1px solid green;
    margin: 20px;
  }
</style>

总结

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值