vue2/vue3 Provide和Inject使用方式

文章详细介绍了在Vue2中使用provide/inject进行非响应式和响应式数据传递,以及Vue3中利用ref和reactive实现响应式数据处理。同时提到了Vue2/3中EventBus作为组件间通信的一种方式。
摘要由CSDN通过智能技术生成

目录

vue2

vue3


vue2

第一种:基本用法(不是响应式)

// 父组件
data() {
  return {
     text: "张三"
  }
},
provide: function() {
  return {
     name: this.text
   }
 },

这种方法传递过来的数据是没有响应性的,当你改变父组件中的name时,子组件中接收的name并不会改变。
官方解释:provide 和 inject 绑定并不是可响应的。这是刻意为之的。然而,如果你传入了一个可监听的对象,那么其对象的 property 还是可响应的。

第二种:响应式

1、传递的参数用一个函数返回

// 父组件
data() {
    return {
      text: "张三"
    }
},
provide: function() {
    return {
      texts: () => this.text
    }
}
// 子组件

// html
<p>{{ textValue }}</p>

// js
inject: ['texts'],
computed: {
   textValue() {
     return this.texts()
   }
}

父组件返回一个自定义的函数,子组件进行computed来进行处理,来实现响应式数据处理。

2、把需要传递的参数定义成一个对象

// 父组件
data() {
    return {
      user:{
        name: "张三"
       }
    }
},
provide: function() {
    return {
      user: this.user
    }
}
// 子组件

// html
<p>{{ userName }}</p>
<p>{{ user.text }}</p>

// js
inject: ['user'],
computed: {
   userName() {
     return this.user.text
   }
}

vue3

直接使用ref 和 reactive方法,来进行响应式数据处理

// 父组件
import { reactive,provide,ref } from 'vue';
provide('page', ref('1'))
provide('user', reactive({
  age: 11,
  name: '张三'
}))
// 子组件
import { inject } from 'vue';
const user = inject("user");
const page = inject("page");

无论任何一个组件内的值发生改变,两个组件的值都会进行响应式的数据更新。

扩展:

vue2/vue3 EventBus事件总线(用于组件通信)

vue3 常用的组件互相通信(父子、兄弟、爷孙、任意组件)

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

余温无痕

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值