我的编程空间,编程开发者的网络收藏夹
学习永远不晚

解析vue的provide和inject使用方法及其原理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

解析vue的provide和inject使用方法及其原理

首先来谈谈我们为什么要使用provide/inject呢?对于爷爷和孙子组件之间,甚至太爷爷组件与孙子组件通信我们用vuex不就ok了。

那事实的确如此,但是,请听我说但是,有时候你项目比较小甚至组件通信的场景很少的,那么你引入vuex就为了那么几个通信传参是不是很浪费啊。有人也可能会想到使用$parent获取父组件实例,来获取data/methods,这种两层就还好,那多层呢,组件嵌套很深的话,你怎么弄?写个函数把$parent再封装一下。那不是很麻烦吗,现成的你不用非要曲线救国。哈哈~扯远了。

不废话那么多了,就告诉你用provide/inject就是解决你这些问题,准没错。让我们看看如何使用呢?反手就是几行简单的代码:


1.父组件提供向子组件要传递的参数
provide() {
    return {
      listType: this.listType,
    }
  }
2.子组件使用:
inject: ['listType'],

当然,你也可以在inject中指定你的默认值和你参数的来源:


inject:{
  listType:{
  from:"par"//provide定义的名字
  default:1
  }
}

好啦!是不是很简单呢。其实就是不管是父组件还是祖先组件都可以向后代组件中注入依赖,无论组件的层次有多深。

再说一些:

provide可以是一个对象,也可以是一个返回对象的函数。

inejct:可以是字符串数组或者一个对象。

有兴趣的话再看看下面的源码部分,也是相当容易了解的:

provide的核心源码:


export function provide<T>(key: InjectionKey<T> | string | number, value: T) {
  if (!currentInstance) {
    if (__DEV__) {
      warn(`provide() can only be used inside setup().`)
    
    }
  } else {
    //获取当前组件的provides,默认实例继承父类的provides对象
    let provides = currentInstance.provides
    //使用父provide对象作为原型来创建自己的provide对象
    const parentProvides =
      currentInstance.parent && currentInstance.parent.provides
    if (parentProvides === provides) {
      provides = currentInstance.provides = Object.create(parentProvides)
    }
    provides[key as string] = value
  }
}
​

inject的核心源码:


export function inject(
  key: InjectionKey<any> | string,
  defaultValue?: unknown,
  treatDefaultAsFactory = false
) {
  //获取当前组件实例
  const instance = currentInstance || currentRenderingInstance
  if (instance) {
  //获取provides
    const provides =
      instance.parent == null
        ? instance.vnode.appContext && instance.vnode.appContext.provides
        : instance.parent.provides
​
    if (provides && (key as string | symbol) in provides) {
      //如果key存在就直接返回
      return provides[key as string]
    } else if (arguments.length > 1) {
      //如果key不存在,设置了默认值就直接返回默认值
      return treatDefaultAsFactory && isFunction(defaultValue)
        ? defaultValue.call(instance.proxy)
        : defaultValue
    } else if (__DEV__) {
      //如果都没有就提示
      warn(`injection "${String(key)}" not found.`)
    }
  } else if (__DEV__) {
    warn(`inject() can only be used inside setup() or functional components.`)
  }
}
​

到此这篇关于解析vue的provide和inject使用方法及其原理的文章就介绍到这了,更多相关vue provide和inject使用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

解析vue的provide和inject使用方法及其原理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue 3 学习笔记—Provide 和 Inject 用法及原理

在父子组件传递数据时,通常使用的是 props 和 emit,父传子时,使用的是 props,如果是父组件传孙组件时,就需要先传给子组件,子组件再传给孙组件。

一文聊聊Vue中provide和inject的使用方法

Vue中如何使用provide与inject?下面本篇文章就来给大家介绍一下Vue中provide和inject的使用方法,希望对大家有所帮助!
2023-05-14

GTK treeview原理及使用方法解析

GtkTreeView 构件是一个高级的构件,利用他你就可以制作出漂亮的普通列表或者是树状的列表。这个构件里可以包含一或者多行。他的构架呢?正是采用了大名鼎鼎的MVC (Model View Controller) 设计框架。也就是
2022-06-04

ADO.NET连接池的原理及其使用方法

本篇内容主要讲解“ADO.NET连接池的原理及其使用方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ADO.NET连接池的原理及其使用方法”吧!不要关闭数据库中所有的连接,至少保证ADO.NE
2023-06-17

VUE中的exportdefault和export使用方法解析

exportdefault和export都能导出一个模块里面的常量,函数,文件,模块等,在其它文件或模块中通过import来导入常量,函数,文件或模块。但是,在一个文件或模块中export,import可以有多个,exportdefault却只能有一个。
2022-12-14

详细分析mysql视图的原理及使用方法

前言: 在MySQL中,视图可能是我们最常用的数据库对象之一了。那么你知道视图和表的区别吗?你知道创建及使用视图要注意哪些点吗?可能很多人对视图只是一知半解,想详细了解视图的同学看过来哟,本篇文章会详细介绍视图的概念、创建及使用方法。 1
2022-05-25

解析Python中回调函数的原理及使用方式

Python回调函数的原理和用法解析回调函数是一种常见的编程技术,尤其在Python中被广泛使用。它可以使我们在异步编程中更加灵活地处理事件和执行任务。本文将对回调函数的原理和用法进行详细解析,并提供具体的代码示例。一、回调函数的原理回
解析Python中回调函数的原理及使用方式
2024-02-02

浅析Vue中插槽和配置代理的使用方法

如何正确快速使用Vue中的插槽和配置代理?下面本篇文章给大家介绍一下Vue中插槽和配置代理的使用方法,希望对大家有所帮助!
2023-05-14

前端Async和Await的原理、流程、使用方法及注意事项

本文实例演示了 Async/Await 的基本用法,原理是利用 Promise 对象的特性,使得异步代码可以更直观、易读。在实际项目中,可以进一步嵌套、组合异步操作,以实现更复杂的异步流程。

阿里云服务器几点刷新信息深入了解其工作原理及使用方法

随着云计算技术的发展,越来越多的企业和个人选择在阿里云服务器上部署应用程序。然而,关于阿里云服务器何时刷新信息的问题,很多用户都存在疑惑。本文将深入探讨阿里云服务器几点刷新信息,帮助用户更好地了解和使用阿里云服务器。阿里云服务器刷新信息的时间:阿里云服务器的刷新信息时间是根据服务器的类型和配置来决定的。一般来说,
阿里云服务器几点刷新信息深入了解其工作原理及使用方法
2023-10-30

阿里云的IP组建代理池在苹果手机上无法使用的原因及解决方法

在使用阿里云的IP组建代理池时,如果苹果手机无法使用,可能是因为以下几个原因:苹果手机的网络设置、系统版本、防火墙设置、网络环境等。本篇文章将针对这些原因,给出相应的解决方法。正文:一、苹果手机网络设置问题苹果手机的网络设置问题可能是造成无法使用阿里云IP组建代理池的主要原因。具体来说,可能是网络设置中未开启代理
阿里云的IP组建代理池在苹果手机上无法使用的原因及解决方法
2023-11-18

Java中的JDBC是如何连接和操作数据库的?(请解释Java数据库连接(JDBC)的工作原理及其用法。)

JDBC工作原理:加载JDBC驱动程序,建立与数据库连接,创建SQL语句,执行SQL语句,处理结果或更新,关闭连接。JDBC用法:导入JDBC包,注册驱动程序,建立连接,创建SQL语句,执行语句,处理结果/更新,关闭连接。示例:连接MySQL数据库并查询数据:导入JDBC包,建立连接,创建SQL语句,执行并处理结果。优势:数据库独立性,标准化接口,广泛使用,易于使用。
Java中的JDBC是如何连接和操作数据库的?(请解释Java数据库连接(JDBC)的工作原理及其用法。)
2024-04-02

夯实Java基础系列4:一文了解final关键字的特性、使用方法,以及实现原理

本系列文章将整理到我在GitHub上的《Java面试指南》仓库,更多精彩内容请到我的仓库里查看https://github.com/h3pl/Java-Tutorial喜欢的话麻烦点下Star哈文章首发于我的个人博客:www.how2pla
2023-06-02

编程热搜

目录