码迷,mamicode.com
首页 > 其他好文 > 详细

介绍Provide以及Inject

时间:2018-12-16 13:18:21      阅读:98      评论:0      收藏:0      [点我收藏+]

标签:something   页面   复杂   ade   some   vue   组件   应用   ide   

介绍 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

标签:something   页面   复杂   ade   some   vue   组件   应用   ide   

原文地址:https://www.cnblogs.com/lovellll/p/10126114.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!