介绍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>
  <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的更多相关文章
- VUE3 之 ref、provide、inject 的使用 - 这个系列的教程通俗易懂,适合新手
		1. 概述 首因效应告诉我们: 在日常交往中,第一印象是非常重要的,好的第一印象能让我们在与人相处时事半功倍. 但也从另一面告诉我们,不能仅凭第一印象去判断一个人,有时虚假的第一印象,也有可能蒙蔽我们 ... 
- vue provide和inject使用
		provide和inject使用场景也是组件传值,尤其是祖父组件--孙组件等有跨度的组件间传值,单向传值(由provide的组件传递给inject的组件). provide 选项应该是一个对象或返回一 ... 
- vue的provide和inject特性
		由来 组件之间的通信可以通过props和$emit的方式进行通信,但是如果组件之间的关系非常复杂的话,通过以上的方式会很麻烦,并且程序会非常脆弱,没有建中性可言. 在==vue2.2.0 中新增pro ... 
- vue中的provide和inject
		vue中的provide和inject:https://blog.csdn.net/viewyu12345/article/details/83011618 
- vue2.0与3.0中的provide和inject 用法
		1.provide/inject有什么用? 常用的父子组件通信方式都是父组件绑定要传递给子组件的数据,子组件通过props属性接收,一旦组件层级变多时,采用这种方式一级一级传递值非常麻烦,而且代码可读 ... 
- VUE004. provide与inject的使用(祖先组件隔多层传静态值给子孙组件)
		provide和inject可以通过祖先组件隔三层四层甚至隔着九层妖塔传值给子孙组件. 需要注意的是这样的传值方式是非响应式的,需要结合自身的应用场景,比如将上传的限制条件通过父组件传值给子组件的子组 ... 
- vue 3 学习笔记 (八)——provide 和 inject 用法及原理
		在父子组件传递数据时,通常使用的是 props 和 emit,父传子时,使用的是 props,如果是父组件传孙组件时,就需要先传给子组件,子组件再传给孙组件,如果多个子组件或多个孙组件使用时,就需要传 ... 
- 051_末晨曦Vue技术_处理边界情况之provide和inject依赖注入
		provide和inject依赖注入 点击打开视频讲解更详细 在此之前,在我们描述访问父级组件实例的时候,展示过一个类似这样的例子: <google-map> <google-map ... 
- vue之provide和inject跨组件传递属性值失败(父组件向子组件传值的两种方式)
		简单介绍:当一个子组件需要用到父组件的父组件的某些参数.那么这个时候为了避免组件重复传参,使用vue的依赖注入是个不错的方法,直接在最外层组件设置一个provide,内部不管多少嵌套都可以直接取到最外 ... 
随机推荐
- JSON对象获取指定元素以及JSON.parse() 与 JSON.stringify() 的区别
			利用 JSON.parse(param) 实现 例: var param = { "name" : "张三", "text" : { &qu ... 
- elasticsearch 中文API(二)
			客户端 有多个地方需要使用Java client: 在存在的集群中执行标准的index, get, delete和search 在集群中执行管理任务 当你要运行嵌套在你的应用程序中的Elasticse ... 
- linux服务器之间传输文件
			转载:https://www.jb51.net/article/82608.htm 1. scp(最近就使用了scp) [优点]简单方便,安全可靠:支持限速参数 [缺点]不支持排除目录[用法]scp就 ... 
- 解决linux机器克隆后eth0不见的问题
			克隆机器之后,两个几的物理地址和ip地址是一样的,导致克隆的机器网络不可用,可以通过通过如下步骤修改: 通过ifconfig –a 命令可查看所有的ip地址配置. 通过这个命令可以发现有一个eth ... 
- csp-s模拟48,49 Tourist Attractions,养花,画作题解
			题面:https://www.cnblogs.com/Juve/articles/11569010.html Tourist Attractions: 暴力当然是dfs四层 优化一下,固定两个点,答案 ... 
- JS的第七种语言类型--symbol
			今天浏览网页的时候发现,JS中有七种语言类型.我的内心???百度一下哪里来的第七种!! 好吧跟着来回顾一下JS的前6种undefined null boolean string numver obje ... 
- sqlserver 创建用户 sp_addlogin
			创建新的 Microsoft® SQL Server™ 登录,使用户得以连接使用 SQL Server 身份验证的 SQL Server 实例. 语法: sp_addlogin [ @loginam ... 
- 深入浅出 Java Concurrency (9): 锁机制 part 4[转]
			本小节介绍锁释放Lock.unlock(). Release/TryRelease unlock操作实际上就调用了AQS的release操作,释放持有的锁. public final boolean ... 
- 公司jar包提交到集群的方法
			yarn -jar xx.jar 此时包会提交到集群上运行 也可以把jar包放到hbase 的lib下面用hbase jar 方式调用 
- 关于 webpack的总结
			一 . 几个基本的概念 1. mode开发模式 // webpack.production.config.js module.exports = { mode: 'production' // 生产模 ... 
