介绍Provide以及Inject

Posted lovellll

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了介绍Provide以及Inject相关的知识,希望对你有一定的参考价值。

介绍 Vue 的 Provide 以及 Inject

Provide 以及 Inject 是 Vue 中用于祖先元素向其所有后台元素注入依赖的接口。

具体用法


// Data.vue
...
export default {
  provide: {
    setData: ‘setData‘
  },
  methods: {
    setdata() {
      //Something
    }
  }
};

// DataItem.vue
...
export default {
  inject: [‘setData‘],
  created() {
    this.setdata();
  }
};
  <data>
    <data-item></data-item>
  </data>
</template>
  • 注意:通过 Inject 获得的属性是不可响应的。

项目中实际应用

在项目中,如需要两个基础组件的父子组件进行通信,又不想写太多业务无关代码,就可以使用 Provide 以及 Inject。

例如:

  <app-header></app-header> <!-- 在App中开启header的显示 -->
  <app-navigation></app-navigation> <!-- 在App中开启navigation的显示 -->
  ...
  <app-footer></app-footer><!-- 在App中开启footer的显示 -->
</app>

仅需要简单的调用组件,而不需要传递 Prop 的值以及定义 Slot。

当然也可以使用一个全局对象实现,使用 Provide 以及 Inject 好处是可多页面复用以及较为简单。

如果需求比较复杂,还是使用一个全局的 Vue 对象或 Vuex 更好。

来源:https://segmentfault.com/a/1190000016874566

以上是关于介绍Provide以及Inject的主要内容,如果未能解决你的问题,请参考以下文章

vue组件通讯之provide / inject

Vue Provide / Inject 详细介绍(跨组件通信响应式变化版本变化)

vue 父组件如何给子组件的组件传值 provide inject

我对vue中组件通信的思考以及provide&inject源码解析

我对vue中组件通信的思考以及provide&inject源码解析

我对vue中组件通信的思考以及provide&inject源码解析