组合式 API:依赖注入
组合式 API:依赖注入
provide()
提供一个值,可以被后代组件注入。
类型
tsfunction provide(key: InjectionKey | string, value: T): void
详细信息
provide()
接受两个参数:第一个参数是要注入的 key,可以是一个字符串或者一个 symbol,第二个参数是要注入的值。当使用 TypeScript 时,key 可以是一个被类型断言为
InjectionKey
的 symbol。InjectionKey
是一个 Vue 提供的工具类型,继承自Symbol
,可以用来同步provide()
和inject()
之间值的类型。与注册生命周期钩子的 API 类似,
provide()
必须在组件的setup()
阶段同步调用。示例
vueimport { ref, provide } from 'vue'import { fooSymbol } from './injectionSymbols'// 提供静态值provide('foo', 'bar')// 提供响应式的值const count = ref(0)provide('count', count)// 提供时将 Symbol 作为 keyprovide(fooSymbol, count)
参考
- 指南 - 依赖注入
- 指南 - 为 provide/inject 标注类型
inject()
注入一个由祖先组件或整个应用 (通过 app.provide()
) 提供的值。
类型
ts// 没有默认值function inject(key: InjectionKey | string): T | undefined// 带有默认值function inject(key: InjectionKey | string, defaultValue: T): T// 使用工厂函数function inject( key: InjectionKey | string, defaultValue: () => T, treatDefaultAsFactory: true): T
详细信息
第一个参数是注入的 key。Vue 会遍历父组件链,通过匹配 key 来确定所提供的值。如果父组件链上多个组件对同一个 key 提供了值,那么离得更近的组件将会“覆盖”链上更远的组件所提供的值。如果没有能通过 key 匹配到值,
inject()
将返回undefined
,除非提供了一个默认值。第二个参数是可选的,即在没有匹配到 key 时使用的默认值。
第二个参数也可以是一个工厂函数,用来返回某些创建起来比较复杂的值。在这种情况下,你必须将
true
作为第三个参数传入,表明这个函数将作为工厂函数使用,而非值本身。与注册生命周期钩子的 API 类似,
inject()
必须在组件的setup()
阶段同步调用。当使用 TypeScript 时,key 可以是一个类型为
InjectionKey
的 symbol。InjectionKey
是一个 Vue 提供的工具类型,继承自Symbol
,可以用来同步provide()
和inject()
之间值的类型。示例
假设有一个父组件已经提供了一些值,如前面
provide()
的例子中所示:vueimport { 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 fn = inject('function', () => {})// 注入一个值,若为空则使用提供的工厂函数const baz = inject('factory', () => new ExpensiveObject(), true)
参考
- 指南 - 依赖注入
- 指南 - 为 provide/inject 标注类型
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!