• provide 和 inject 通常成对一起使用,使一个祖先组件作为其后代组件的依赖注入方,无论这个组件的层级有多深都可以注入成功,只要他们处于同一条组件链上。

inject 选项应该是以下两种之一:

  • 一个字符串数组
  • 一个对象,其 key 名就是在当前组件中的本地绑定名称,而它的值应该是以下两种之一:
    • 匹配可用注入的 key (string 或者 Symbol)
    • 一个对象
      • 它的 from 属性是一个 key (string 或者 Symbol),用于匹配可用的注入
      • 它的 default 属性用作候补值。和 props 的默认值类似,如果它是一个对象,那么应该使用一个工厂函数来创建,以避免多个组件共享同一个对象。

optionsApi

  • App
    • Father
      • Child
  • provide / inject

App

export default {
    provide: {
        pub: 'pub provider'
    }
}

export default {
    name: 'Child',
    inject:['pub'] 
}

//  use this 
export default {
    name: 'Father',
    components: {
        chil: ChildVue
    },
    provide() {
        return {
            pub: this.msg
        }
    },

    data() {
        return {
            msg: 'hello  is use this !!'
        }
    }
}

compostionApi

  • provider(key,value)

  • inject('key','defaultValue')

  • 类型

function provide<T>(key: InjectionKey<T> | string, value: T): void
  • 详细信息

provide() 接受两个参数:第一个参数是要注入的 key,可以是一个字符串或者一个 symbol,第二个参数是要注入的值。


<script setup>
import { ref, provide } from 'vue'
import { fooSymbol } from './injectionSymbols'

// 提供静态值
provide('foo', 'bar')

// 提供响应式的值
const count = ref(0)
provide('count', count)

// 提供时将 Symbol 作为 key
provide(fooSymbol, count)
</script>





<script setup>
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)
</script>