Vue组件通信:依赖注入(provide + inject)

Vue3文档:https://cn.vuejs.org/guide/components/provide-inject.html

Prop 逐级透传问题

多级组件 props 传值,组件链路非常长,不利于维护
在这里插入图片描述
provide 和 inject 可以帮助我们解决这一问题

在这里插入图片描述

Provide (提供)

import {
    provide } from 'vue'

export default {
   
  setup() {
   
    provide(/* 注入名 */ 'message', /* 值 */ 'hello!')
  }
}

provide() 函数接收两个参数:
第一个参数被称为注入名(key),可以是一个字符串或是一个 Symbol。、
第二个参数是提供的值(value),值可以是任意类型

Inject (注入)

import {
    inject } from 'vue'

export default {
   
  setup() {
   
    const message = inject('message')
    return {
    message }
  }
}

注入默认值​

默认情况下,inject 假设传入的注入名会被某个祖先链上的组件提供。如果该注入名的确没有任何组件提供,则会抛出一个运行时警告。
如果在注入一个值时不要求必须有提供者,那么我们应该声明一个默认值,和 props 类似:

// 如果没有祖先组件提供 "message"
// `value` 会是 "这是默认值"
const value = inject('message', '这是默认值')

使用 Symbol 作注入名

如果构建大型的应用,包含非常多的依赖提供,建议最好使用 Symbol 来作为注入名以避免潜在的冲突。
通常推荐在一个单独的文件中导出这些注入名 Symbol:

// keys.js
export const myInjectionKey = Symbol()
// 在供给方组件中
import {
    provide } from 'vue'
import {
    myInjectionKey } from './keys.js'

provide(myInjectionKey, {
    /*
  要提供的数据
*/ });
// 注入方组件
import {
    inject } from 'vue'
import {
    myInjectionKey } from './keys.js'

const injected = inject(myInjectionKey)

相关推荐

  1. Vue通信

    2023-12-14 04:06:01       44 阅读
  2. vue循环依赖

    2023-12-14 04:06:01       30 阅读
  3. vue通信

    2023-12-14 04:06:01       51 阅读
  4. vue 通讯

    2023-12-14 04:06:01       57 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-14 04:06:01       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-14 04:06:01       100 阅读
  3. 在Django里面运行非项目文件

    2023-12-14 04:06:01       82 阅读
  4. Python语言-面向对象

    2023-12-14 04:06:01       91 阅读

热门阅读

  1. 光伏发电技术的应用领域有哪些?

    2023-12-14 04:06:01       63 阅读
  2. 【js或momentJs获取当前月的起止日期】

    2023-12-14 04:06:01       63 阅读
  3. 智能查券机器人:导购APP的新趋势

    2023-12-14 04:06:01       59 阅读
  4. Linux中的磁盘挂载与取消

    2023-12-14 04:06:01       58 阅读
  5. 【FPGA】篮球比赛计分器

    2023-12-14 04:06:01       51 阅读
  6. RocketMQ的监控和管理工具有哪些❓

    2023-12-14 04:06:01       62 阅读
  7. python 多进程

    2023-12-14 04:06:01       48 阅读
  8. mysql select count 非常慢

    2023-12-14 04:06:01       53 阅读
  9. 项目优化过程

    2023-12-14 04:06:01       53 阅读
  10. ExecuteScalar()方法

    2023-12-14 04:06:01       58 阅读
  11. Android : LifeCycles_简单应用

    2023-12-14 04:06:01       65 阅读
  12. 【MyBatis】拦截查询结果同时动态替换

    2023-12-14 04:06:01       58 阅读
  13. 20230907docker安装MySQL配置

    2023-12-14 04:06:01       55 阅读