vue中provide和inject怎样用,原理如何理解
Admin 2022-06-29 群英技术资讯 743 次浏览
首先来谈谈我们为什么要使用provide/inject呢?对于爷爷和孙子组件之间,甚至太爷爷组件与孙子组件通信我们用vuex不就ok了。
那事实的确如此,但是,请听我说但是,有时候你项目比较小甚至组件通信的场景很少的,那么你引入vuex就为了那么几个通信传参是不是很浪费啊。有人也可能会想到使用$parent
获取父组件实例,来获取data/methods,这种两层就还好,那多层呢,组件嵌套很深的话,你怎么弄?写个函数把$parent
再封装一下。那不是很麻烦吗,现成的你不用非要曲线救国。哈哈~扯远了。
不废话那么多了,就告诉你用provide/inject就是解决你这些问题,准没错。让我们看看如何使用呢?反手就是几行简单的代码:
1.父组件提供向子组件要传递的参数 provide() { return { listType: this.listType, } } 2.子组件使用: inject: ['listType'],
当然,你也可以在inject中指定你的默认值和你参数的来源:
inject:{ listType:{ from:"par"//provide定义的名字 default:1 } }
好啦!是不是很简单呢。其实就是不管是父组件还是祖先组件都可以向后代组件中注入依赖,无论组件的层次有多深。
再说一些:
provide可以是一个对象,也可以是一个返回对象的函数。
inejct:可以是字符串数组或者一个对象。
有兴趣的话再看看下面的源码部分,也是相当容易了解的:
provide的核心源码:
export function provide<T>(key: InjectionKey<T> | string | number, value: T) { if (!currentInstance) { if (__DEV__) { warn(`provide() can only be used inside setup().`) } } else { //获取当前组件的provides,默认实例继承父类的provides对象 let provides = currentInstance.provides //使用父provide对象作为原型来创建自己的provide对象 const parentProvides = currentInstance.parent && currentInstance.parent.provides if (parentProvides === provides) { provides = currentInstance.provides = Object.create(parentProvides) } provides[key as string] = value } }
inject的核心源码:
export function inject( key: InjectionKey<any> | string, defaultValue?: unknown, treatDefaultAsFactory = false ) { //获取当前组件实例 const instance = currentInstance || currentRenderingInstance if (instance) { //获取provides const provides = instance.parent == null ? instance.vnode.appContext && instance.vnode.appContext.provides : instance.parent.provides if (provides && (key as string | symbol) in provides) { //如果key存在就直接返回 return provides[key as string] } else if (arguments.length > 1) { //如果key不存在,设置了默认值就直接返回默认值 return treatDefaultAsFactory && isFunction(defaultValue) ? defaultValue.call(instance.proxy) : defaultValue } else if (__DEV__) { //如果都没有就提示 warn(`injection "${String(key)}" not found.`) } } else if (__DEV__) { warn(`inject() can only be used inside setup() or functional components.`) } }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了VSCode中 Eslint和Prettier冲突问题,既然使用 eslint规范,我的理解上当然是不能去修改eslint,因为这是共用规范,修改了就没有再使用的必要了,所以我是不推荐修改eslint的方式,本文给结合实例代码给大家详细讲解,需要的朋友可以参考下
这篇文章主要给大家分享的是JavaScript 的反射学习技巧,主要是区别在于所有的函数对象属性过于复杂,而且额外增加可能会导致程序行为不合理,所以扩展 Reflect 函数来专门对函数对象处理调用方法,构造对象,获取或者设置属性等相关操作。下面一起进入文章内容吧
本篇文章带大家继续angular的学习,简单了解一下angular中Directive指令的使用,希望对大家有所帮助!
今天给大家分享的是JavaScript怎样实现一个简易的登录窗体的内容,小编觉得挺实用的,因此分享给大家做个参考,实现效果及代码如下,接下来跟随小编一起看看吧。
//文件处理类varfs=require('fs');varpath=require('path');varutil=require('util');varFile={in:function(content,flag){this.writeToFile("app.log",content,flag);},on:
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008