Vue.js组件开发-在setup函数中使用provide

在Vue.js 3的组合式API中,setup函数是组件的初始化逻辑所在地,可以在这里使用provide函数来向组件的后代提供数据或方法。这些数据或方法随后可以在任何后代组件(子组件、孙组件等)中通过inject函数被注入和使用。

步骤:

1‌.导入必要的API‌:

首先,需要从vue包中导入provide函数。

‌2.在setup函数中调用provide‌:

在setup函数内部,调用provide来提供数据或方法。provide函数接受两个参数:一个键(通常是字符串)和你要提供的值。

‌3.在后代组件中使用inject‌:

在后代组件的setup函数中,可以使用inject函数来接收由祖先组件提供的值。inject函数的参数是想要注入的键,它会返回对应的值。

示例:

展示如何在父组件的setup函数中使用provide,并在子组件中使用inject:

‌父组件(ProviderComponent.vue)‌:

html 复制代码
<template>
  <div>
    <h1>Provider Component</h1>
    <ChildComponent />
  </div>
</template>

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

export default {
  components: {
    ChildComponent
  },
  setup() {
    const state = reactive({
      message: 'Hello from Provider!'
    });

    provide('sharedState', state);

    // setup函数通常不返回任何内容,除非需要暴露响应式数据给模板
    // 在这个例子中,我们不需要返回任何内容
  }
};
</script>

子组件(ChildComponent.vue)‌:

html 复制代码
<template>
  <div>
    <h2>Child Component</h2>
    <p>{{ sharedState.message }}</p>
  </div>
</template>

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

export default {
  setup() {
    const sharedState = inject('sharedState');

    // 返回需要暴露给模板的数据
    return {
      sharedState
    };
  }
};
</script>

说明:

这个例子中,ProviderComponent是父组件,它通过provide函数提供了一个名为sharedState的响应式对象。ChildComponent是子组件,它通过inject函数注入了sharedState,并在模板中使用了它。

**注意:**provide和inject的键(在这个例子中是'sharedState')在父组件和子组件之间必须匹配。此外,由于sharedState是一个响应式对象,所以当它的内容发生变化时,子组件的视图也会自动更新。

相关推荐
用户516816614584114 小时前
Vue Router 路由懒加载引发的生产页面白屏问题
vue.js·vue-router
前端缘梦14 小时前
Vue Keep-Alive 组件详解:优化性能与保留组件状态的终极指南
前端·vue.js·面试
Simon_He14 小时前
这次来点狠的:用 Vue 3 把 AI 的“碎片 Markdown”渲染得又快又稳(Monaco 实时更新 + Mermaid 渐进绘图)
前端·vue.js·markdown
王同学QaQ19 小时前
Vue3对接UE,通过MQTT完成通讯
javascript·vue.js
华仔啊20 小时前
基于 RuoYi-Vue 轻松实现单用户登录功能,亲测有效
java·vue.js·后端
艾小码20 小时前
告别Vue混入的坑!Composition API让我效率翻倍的3个秘密
前端·javascript·vue.js
Gracemark2 天前
高德地图-地图选择经纬度问题【使用输入提示-使用Autocomplete进行联想输入】(复盘)
vue.js
天下无贼2 天前
【手写组件】 Vue3 + Uniapp 手写一个高颜值日历组件(含跨月补全+今日高亮+选中状态)
前端·vue.js
洋葱头_2 天前
vue3项目不支持低版本的android,如何做兼容
前端·vue.js
奔跑的蜗牛ing2 天前
Vue3 + Element Plus 输入框省略号插件:零侵入式全局解决方案
vue.js·typescript·前端工程化