vue高级组件之provide与inject怎么使用


本文小编为大家详细介绍“vue高级组件之provide与inject怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“vue高级组件之provide与inject怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.父子组件,通过prop2.非父子组件,通过vuex或根vue转载器通常是以上两种情况,然而还有一种比较特殊的情况,即孙子组件或更深层次的组件通信1.下面是a.vue2.下面是son.vue很容易看出,如果父组件需要与grandson通信,除了vuex,必须先与son组件通信,再由son与grandson通信,在层级比较少的情况下也无可厚非,但是层级一旦多起来是很可怕的有人会问为什么不用vuex,简单省事,有很多免费云主机域名为了这个引入vuex会导致代码性价比比较低,项目本身没有使用vuex的必要那么这种情况下provide / inject就登场了1.provide就相当于加强版父组件prop2.inject就相当于加强版子组件的props因为以上两者可以在父组件与子组件、孙子组件、曾孙子…组件数据交互,也就是说不仅限于prop的父子组件数据交互,只要在上一层级的声明的provide,那么下一层级无论多深都能够通过inject来访问到provide的数据1.父级组件如下2.孙子组件,注意这里是孙子组件,父级 -> 子组件 -> 孙子组件三个层级关系这里可以通过inject直接访问其两个层级上的数据,其用法与props完全相同,同样可以参数校验等这么做也是有明显的缺点的,在任意层级都能访问导致数据追踪比较困难,不知道是哪一个层级声明了这个或者不知道哪一层级或若干个层级使用了,因此这个属性通常并不建议使用能用vuex的使用vuex,不能用的多传参几层,但是在做组件库开发时,不对vuex进行依赖,且不知道用户使用环境的情况下可以很好的使用在vue3中的父子组件一般都用provide 和 inject 传值父组件中引入和注册了子组件之后在script标签下引入provide就可以将父组件中的变量或方法传递出去在子组件中就可以用inject来接收一下 不管子组件的层级有多深都可以接收到provide(‘变量名’,’变量’)inject(‘变量名’)provide(‘事件名’,’事件’)inject(‘事件名’,’事件’)读到这里,这篇“vue高级组件之provide与inject怎么使用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注百云主机行业资讯频道。

相关推荐: js多维数组降维的方法有哪些

这篇文章主要介绍“js多维数组降维的方法有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“js多维数组降维的方法有哪些”文章能帮助大家解决问题。多维数组降维也就是数组扁平化数组扁平化的方法有很多种,但是我主要用五种,…

免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。

(0)
打赏 微信扫一扫 微信扫一扫
上一篇 07/06 17:12
下一篇 07/06 17:12

相关推荐