Vue 3.0 的组合式 API 提供了 provide 和 inject 这两个函数,用于在父组件和子组件之间进行依赖注入。这使得在组件之间共享状态变得更加灵活。

provide 函数

provide 函数用于在父组件中提供数据,这些数据可以被子孙组件访问。provide 接受两个参数:键(key)和值(value)。
<script>
import { provide } from 'vue';

export default {
  setup() {
    const sharedData = 'Shared Data';

    provide('sharedKey', sharedData);

    return {};
  }
};
</script>

在上述例子中,父组件使用 provide 提供了一个名为 sharedKey 的键,以及与之关联的值 sharedData。

inject 函数

inject 函数用于在子孙组件中注入提供的数据。它接受一个键的数组或对象,并返回相应的值。
<script>
import { inject } from 'vue';

export default {
  setup() {
    const injectedData = inject('sharedKey', 'Default Value');

    return {
      injectedData
    };
  }
};
</script>

在上述例子中,子孙组件使用 inject 注入了名为 sharedKey 的键,并得到了提供的值,如果没有提供的话,使用了默认值 'Default Value'。

示例

下面是一个更完整的例子,展示了如何在父组件中提供数据,然后在子组件中注入并使用这些数据。
<template>
  <div>
    <p>Parent Component: {{ sharedData }}</p>
    <ChildComponent />
  </div>
</template>

<script>
import { provide } from 'vue';
import ChildComponent from './ChildComponent.vue';

export default {
  setup() {
    const sharedData = 'Shared Data';

    provide('sharedKey', sharedData);

    return {
      sharedData
    };
  },
  components: {
    ChildComponent
  }
};
</script>
<!-- ChildComponent.vue -->
<template>
  <div>
    <p>Child Component: {{ injectedData }}</p>
  </div>
</template>

<script>
import { inject } from 'vue';

export default {
  setup() {
    const injectedData = inject('sharedKey', 'Default Value');

    return {
      injectedData
    };
  }
};
</script>

在这个例子中,父组件通过 provide 提供了 sharedKey 的数据,然后子组件通过 inject 注入并使用了这个数据。这种方式可以实现非常灵活的组件通信,特别适用于跨越多层级的组件关系。


转载请注明出处:http://www.pingtaimeng.com/article/detail/520/Vue 3.0