依赖注入 provide/inject
child.vue
<template>
<span>响应值示例 </span>
<span>count : {
{count}}</span>
</template>
<script setup>
import {
inject } from 'vue'
import {
fooSymbol } from './keys.js'
// 注入值的默认方式
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>
parent.vue
<template>
<a-input v-model:value.number="count"></a-input>
<br> <br>
<childvue />
</template>
<script setup>
import {
ref, provide } from 'vue'
import {
fooSymbol } from './keys.js'
import childvue from './child.vue'
// 提供静态值
provide('foo', 'bar')
// 提供响应式的值
const count = ref(0)
provide('count', count)
// 提供时将 Symbol 作为 key
provide(fooSymbol, count)
</script>
<style lang="less" scoped>
</style>
keys.js
export const fooSymbol = Symbol()