一文聊聊Vue中provide和inject的使用方法
时间:2023-04-10 22:40
Vue中如何使用provide与inject?下面本篇文章就来给大家介绍一下Vue中provide和inject的使用方法,希望对大家有所帮助! 在 也就是父子组件间的通信,父组件上市通过自定义属性,而子组件间通过 在 还是要从具体的实例出发 定义:提供一个值,可以被后代组件注入 实现: 父组件有一个 provide(第一个参数,第二个参数),接收两个参数,第一个参数是要注入的 具体示例代码如下所示 通过上面的 定义: 注入一个由祖先(父)组件或整个应用提供的值 实现: 接收父(祖)组件传递过来的值 如果没有能通过 第二个参数是可选的,即没有匹配到 那么必须将 与注册生命周期钩子的 具体示例代码 在孙组件中的模板即可以读取,从父组件传递过来的数据也是支持响应式的 若使用解构时,则模板中可直接使用变量 若使用解构时,则模板中可直接使用变量 注意 如果是解构变量,想要数据响应式,那么需要使用 如下是完整的示例 基本上用第一种注入默认值的方式,使用是最多的,接收父组件提供传递过来的值 那么就可以使用这种方式进行传递数据的,这在平时的一些业务开发中,还是有些用的,而在面试当中也是一个高频面试问题,怎么解决跨级组件,非父子组件通信 (学习视频分享:vuejs入门教程、编程基础视频) 以上就是一文聊聊Vue中provide和inject的使用方法的详细内容,更多请关注Gxl网其它相关文章!vue2.0
里面provide
与inject
是以选项式(配置)API
的方式在组件中进行使用的,解决的是跨组件(祖孙)间通信的一种方式props
这种方式接收,如果想要一层一层的传递,这种方式就会比较麻烦,不灵活provide
与inject
就是解决:怎么从祖组件的数据,传递到孙组件,实现跨级组件传递数据的vue3.0
里面,同样提供了provide
与inject
,使用起来更简单方便,单纯的从概念上去看,是比较抽象,难以理解的。【相关推荐:vuejs视频教程、web前端开发】provide()函数
provide
,选项来提供数据,后代组件中有一个inject
选项来开始使用父组件传递过来的数据key
,它可以是一个字符串或一个symbol
,第二个参数是要注入的值(具体要传递给子孙组件的数据)provide
是vue
官方提供的componsition API
import {reactive,provide} from "vue";let person = reactive({name: 'itclanCoder',website: 'https://coder.itclan.cn'});provide('person',person);
provide
提供一个值,就可以了的,那怎么样把这个数据传递到子孙组件,那么就需要用到inject
了的inject()函数
inject(第一个参数,第二个参数(可选))
:第一个参数是注入的key
,来自父(祖)组件,它们两者是需要保持一致的Vue
会遍历父组件链,通过匹配key来确定所提供的值,如果父组件链上多个组件对同一个key
提供了之,那么离得更近的将会覆盖链上更远的组件所提供的值key
匹配到的值,inject()
函数将返回undefined
,除非提供一个默认值key
时,使用默认值,它也可以是一个函数,用来返回某些创建起来比较复杂的值,如果默认值本身就是一个函数false
作为第三个参数传入,表明这个函数就是默认值,而不是一个工厂函数API
类似,inject()
必须在组件的setup()
阶段同步调用import {inject,toRefs} from "vue";const person = inject('person');// 若是使用解构,则会丢失响应式,修改数据时,页面不会更新,具体解决,可以引入toRef或toRefs函数const {name,website} = toRefs(person);
{{person.name}}---{{person.website}}
{{name}}--{{website}}
{{name}}--{{website}}
toRef()
或toRefs()
将数据进行转化为响应式import { inject } from 'vue'import { fooSymbol } from './injectionSymbols'// 注入值的默认方式const foo = inject('foo') // 注入响应式的值const count = inject('count')// 通过 Symbol 类型的 key 注入const foo2 = inject(fooSymbol)// 注入一个值,若为空则使用提供的默认值const bar = inject('foo', 'default value')// 注入一个值,若为空则使用提供的工厂函数const baz = inject('foo', () => new Map())// 注入时为了表明提供的默认值是个函数,需要传入第三个参数const fn = inject('function', () => {}, false)
总结
provide()
与inject()
的使用比较简单,就是解决跨组件间通信的一种方式,对于层级嵌套比较深的组件,若子孙组件想要使用父组件中的数据