首页 > 其他分享 >Vue3.0文档学习心得--依赖注入

Vue3.0文档学习心得--依赖注入

时间:2022-12-13 17:33:06浏览次数:62  
标签:const -- 学习心得 provide Vue3.0 inject key 组件 注入

1.provide():在祖先组件或整个应用 (通过 app.provide()) 提供一个值,可以被后代组件注入。

(1)第一个参数是要注入的 key,可以是一个字符串或者一个 symbol,第二个参数是要注入的值。

(2)当使用 TypeScript 时,key 可以是一个被类型断言为 InjectionKey 的 symbol。InjectionKey 是一个 Vue 提供的工具类型,继承自 Symbol,可以用来同步 provide() 和 inject() 之间值的类型。

(3)与注册生命周期钩子的 API 类似,provide() 必须在组件的 setup() 阶段同步调用。

<script setup>
import { ref, provide } from 'vue'
import { fooSymbol } from './injectionSymbols'

// 提供静态值
provide('foo', 'bar')

// 提供响应式的值
const count = ref(0)
provide('count', count)

// 提供时将 Symbol 作为 key
provide(fooSymbol, count)
</script>

 

2.inject():在后代组件由祖先组件或整个应用 (通过 app.provide()) 提供的值。

(1)第一个参数是注入的 key。Vue 会遍历父组件链,通过匹配 key 来确定所提供的值。如果父组件链上多个组件对同一个 key 提供了值,那么离得更近的组件将会“覆盖”链上更远的组件所提供的值。如果没有能通过 key 匹配到值,inject() 将返回 undefined,除非提供了一个默认值。
<script setup>
import { inject } from 'vue'
import { fooSymbol } from './injectionSymbols'

// 注入值的默认方式
const foo = inject('foo')

// 注入响应式的值
const count = inject('count')

// 通过 Symbol 类型的 key 注入
const foo2 = inject(fooSymbol)

</script>

(2)第二个参数是可选的,即在没有匹配到 key 时使用的默认值。它也可以是一个工厂函数,用来返回某些创建起来比较复杂的值。如果默认值本身就是一个函数,那么你必须将 false 作为第三个参数传入,表明这个函数就是默认值,而不是一个工厂函数。(工厂函数即自带函数)

// 注入一个值,若为空则使用提供的默认值
const bar = inject('foo', 'default value')

// 注入一个值,若为空则使用提供的工厂函数
const baz = inject('foo', () => new Map())

// 注入时为了表明提供的默认值是个函数,需要传入第三个参数
const fn = inject('function', () => {}, false)

 

标签:const,--,学习心得,provide,Vue3.0,inject,key,组件,注入
From: https://www.cnblogs.com/LylePark/p/16979404.html

相关文章

  • Gdiplus-Lock up your bits
    TheBitmapclassprovidesthe LockBits andcorresponding UnlockBits methodswhichenableyoutofixaportionofthebitmappixeldataarrayinmemory,acc......
  • Xilinx_ISE和ModelSim的联合使用方法 / 从Xilinx ISE 14.7启动ModelSim时遇到的问题
    解决方法:前提是安装了xilinxise14.7和modelsimse10.1a1〉从Windows的StartMenu开始,XilinxISEDesignSuite14.7—〉EDK—〉Tools—〉CompileSimulationLibrari......
  • 改变ComboBox控件的高度
      非常简单, CComboBox*  pCtl =(CComboBox*)GetDlgItem(IDC_CBCOLORPICKER);  pCtl->SendMessage(CB_SETITEMHEIGHT,(WPARAM)-1,(LPARAM)18);  //改变控件本......
  • 跨境电商独立站如何引流?
    当今互联网时代,全球电商的份额越来越高,市场上很多主流的跨境电商平台大家都知道。说到跨境电商独立站,很多小伙伴都不熟悉。其实跨境电商独立站很多年前就很流行,不是最近才开......
  • 网络无线传输方案
    有线传输网络相信大家已经非常熟稔了,那无线传输网络有没有了解的呢?有没有和小编之前一样觉得无线网桥只能用来传输数据的呢?今天就说说小编亲测的无线传输网络的一个方案和大......
  • 分块内存映射处理大文件-例子
    内存映射文件可以用于3个不同的目的•系统使用内存映射文件,以便加载和执行.exe和DLL文件。这可以大大节省页文件空间和应用程序启动运行所需的时间。•可以使用内存映射......
  • 厘清企业数据治理难题,《网易数据治理白皮书》重磅发布!
    数字化时代下,无论是企业的管理者,还是一线员工无时无刻不在和数据打交道,如何用好数据、挖掘更多数据价值是每家企业都将或正在面临的问题。因此,有效进行治理数据,是推动企业......
  • 每日一题-数论
    Codeforceseduround139D-LuckyChains问题描述给正整数\(x,y(x<y)\),如果\(gcd(x,y),gcd(x+1,y+1)\dotsgcd(x+k,y+k)都为1\),则称这些数为LuckyChain,......
  • java web 大文件上传源代码
    ​ 前言:因自己负责的项目(jetty内嵌启动的SpringMvc)中需要实现文件上传,而自己对java文件上传这一块未接触过,且对Http协议较模糊,故这次采用渐进的方式来学习文件上传的......
  • 回车与换行的区别
    1、两个控制字符的介绍以前打字机中,每行后面加两个表示结束的字符。一个叫做 “回车”return(/r),告诉打字机把打印头定位在左边界 ;另一个叫做 “换行”newline(/n),告诉打......