vue2中provide/inject的使用和响应式传值


前言

官网概念:这对选项需要一起使用,以允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在其上下游关系成立的时间里始终生效。


一、基本用法

在父组件中使用provide传值,在子组件中用inject接收。

// 父组件
data() {
  return {
     name: "卷儿"
  }
},
provide: function() {
  return {
     name: this.name
   }
 },

// 子组件
inject: ['name'],

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

二、响应式

1.方法一:传递的参数用一个方法返回

// 父组件
data() {
    return {
      name: "卷儿"
    }
  },
  provide: function() {
    return {
      newName: () => this.name
    }
// 子组件
inject: ['newName'],
computed: {
   hnewName() {
     return this.newName()
   }
 }
<!-- 子组件中的使用方式 -->
<h2>{{ hnewName }}</h2> <!-- 推荐使用这种方法 -->
<h2>{{ newName() }}</h2>

2.方法二:把需要传递的参数定义成一个对象

官方解释:provide 和 inject 绑定并不是可响应的。这是刻意为之的。然而,如果你传入了一个可监听的对象,那么其对象的 property 还是可响应的。

// 父组件
data() {
    return {
      obj: {
        name: "卷儿"
      }
    }
  },
  provide: function() {
    return {
    // 传递一个对象
      obj: this.obj
    }
  },
// 子组件
inject: ['obj'],
computed: {
	// 也可以不用计算属性重新定义
   objName() {
     return this.obj.name
   }
 }
<!-- 子组件中的使用方法 -->
<h2>obj的name: {{objName}}</h2>
<h2>obj的name: {{obj.name}}</h2>

总结

主要解决深层次的组件嵌套,祖先组件向子孙组件之间传值。
一层嵌套的父子组件可以使用props来传值,props本身就是有相应性的。
根据自身代码选择合适的传值方式,并不一定非要用provide/inject的传值。

  • 22
    点赞
  • 62
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vueprovideinject是一对用于在父组件和子组件之间传递数据的API。但是,当我们在provide提供响应式数据时,它并不会自动触发子组件的更新。 为了实现响应式数据更新,我们可以使用Vue的$forceUpdate()方法。具体来说,我们可以在provide提供一个包含响应式数据的对象,并在子组件使用inject将其注入。然后,在父组件更新数据时,我们可以在更新数据后手动调用$forceUpdate()方法强制更新子组件。 以下是一个示例代码: 父组件: ``` <template> <div> <ChildComponent /> </div> </template> <script> import ChildComponent from './ChildComponent.vue'; export default { provide() { return { data: this.data } }, data() { return { data: {} } }, methods: { updateData() { this.data.name = 'new name'; this.$forceUpdate(); } }, components: { ChildComponent } } </script> ``` 子组件: ``` <template> <div> {{data.name}} </div> </template> <script> export default { inject: ['data'], created() { console.log(this.data.name); // 输出空字符串 }, mounted() { console.log(this.data.name); // 输出空字符串 }, updated() { console.log(this.data.name); // 输出'new name' } } </script> ``` 在这个例子,父组件提供了一个包含响应式数据的data对象,并将其注入到子组件。在父组件更新数据时,我们手动调用了$forceUpdate()方法,从而强制更新了子组件的视图。在子组件,我们可以通过inject注入父组件提供的data对象,并在updated钩子函数获取更新后的数据。 需要注意的是,$forceUpdate()方法会触发所有子组件的更新,因此使用时需要谨慎。如果可能的话,我们应该尽量避免使用这个方法,而是通过Vuex或事件总线等其他方式来进行组件间的通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值