1. 概述

首因效应告诉我们:

在日常交往中,第一印象是非常重要的,好的第一印象能让我们在与人相处时事半功倍。

但也从另一面告诉我们,不能仅凭第一印象去判断一个人,有时虚假的第一印象,也有可能蒙蔽我们的双眼,影响我们的判断,正所谓“路遥知马力,日久见人心”。

言归正传,今天我们来聊聊 VUE 中 ref、provide、inject 的使用。

2.  ref、provide、inject

2.1 使用 ref 获取 dom 元素

<body>
<div id="myDiv"></div>
</body>
<script>
const app = Vue.createApp({
mounted() {
console.info(this.$refs.div1)
this.$refs.div1.innerHTML = 'hello';
},
template:`
<div>
<div ref="div1"> </div>
</div>
`
});
const vm = app.mount("#myDiv");
</script>

在 VUE 中,获取 dom 元素就是这么简单,在想获取的 dom 元素上增加属性 ref="标识名称",然后在方法中使用 this.$refs.标识名称 ,即可获取该 dom 元素

注意:使用 this.$ref.标识名称 获取 dom 元素时,必须是在 dom 元素渲染完成后,也就是说,必须是在 mounted 周期方法中获取 或是 元素渲染完成后,使用触发方法获取

2.2 使用 ref 获取子组件

    const app = Vue.createApp({
mounted() {
this.$refs.myCom.method1();
},
template:`
<div>
<my-com ref="myCom" />
</div>
`
});
app.component("my-com", {
methods : {
method1 () {
alert("hello");
}
},
template: `
<div>
component1
</div>
`
});

ref 的另一个功能,就是获取子组件对象

该例中主组件使用子组件时使用 <my-com ref="myCom" /> 的写法,给组件添加了 标识名称 myCom,

然后在方法中使用 this.$refs.myCom.method1(); 得到子组件对象,并调用了子组件中的方法。

2.3 多组件参数传递

如果有一个参数,需要从父组件传递到子组件,然后子组件再传递给子子组件,根据我们之前学的知识,可以这么写

    const app = Vue.createApp({
data(){
return {
num : 1
}
},
template:`
<div>
<my-com-1 :num="num" />
</div>
`
});
app.component("my-com-1", {
props:["num"],
template: `
<my-com-2 :num="num" />
`
});
app.component("my-com-2", {
props:["num"],
template: `
<div>
{{num}}
</div>
`
});

这样写的确可以实现,但似乎不太优雅,所有的子组件都需要接收参数,并再往下传递,这里有一个更好的写法

2.4 多组件参数传递优化

   const app = Vue.createApp({
data(){
return {
num : 1
}
},
provide() {
return {
num_2 : this.num
}
},
template:`
<div>
<my-com-1 />
</div>
`
}); app.component("my-com-1", {
template: `
<my-com-2 />
`
}); app.component("my-com-2", {
inject:["num_2"],
template: `
<div>
{{num_2}}
</div>
`
});

这样写就优雅多了,只需要在父组件使用 provide 传参,在需要使用数据的子组件,使用 inject 接收即可

注意:使用 provide 、inject 的方式传参,当父组件的 num 发生改变时,页面不会重新渲染,至于如何重新渲染,在后面的文章中会有介绍。

3. 综述

今天聊了一下 VUE3 的 ref、provide、inject 的使用,希望可以对大家的工作有所帮助,下一节我们开始讲 Vue 中 动画 的相关知识,敬请期待

欢迎帮忙点赞、评论、转发、加关注 :)

关注追风人聊Java,这里干货满满,都是实战类技术文章,通俗易懂,轻松上手。

4. 个人公众号

追风人聊Java,欢迎大家关注

VUE3 之 ref、provide、inject 的使用 - 这个系列的教程通俗易懂,适合新手的更多相关文章

  1. VUE3 之 动画与过渡的实现 - 这个系列的教程通俗易懂,适合新手

    1. 概述 光环效应告诉我们: 当一个人在某一方面取得了巨大的成功,人们就会给他贴上正面的标签,这个人从此就被"优秀"的光环所笼罩,他做的一切,人们都认为是正确的. 例如:越是名气 ...

  2. VUE3 之 多个 v-model 绑定及 v-model 修饰符的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 洛克定律告诉我们: 当我们的目标很远大,远到我们都看不到终点时,放弃几率就会很大,就像跑马拉松比赛,由于时间长.距离长,很多选手都会选择在中途放弃. 其实有个好办法,就是拆分,把大目标拆分 ...

  3. VUE3 之 插槽的使用 - 这个系列的教程通俗易懂,适合新手

    1. 概述 非理性定律告诉我们: 人们总是习惯于以情感去判断眼前的事物,非理性的去做决定. 对于长远的利益,人们更愿意去选择短期的利益. 因此在做决定前要让自己冷静,理性的分析,让自己看的更远. 言归 ...

  4. VUE3 之 作用域插槽 - 这个系列的教程通俗易懂,适合新手

    1. 概述 破窗效应告诉我们: 当一个建筑物窗户的玻璃完好无损时,很少有人想去破坏它,当有一个人破坏了一块窗户的玻璃,其他窗户的玻璃也很快会被人破坏. 同理,一个很干净的地方,人们不好意思去丢垃圾,但 ...

  5. VUE3 之 动态组件 - 这个系列的教程通俗易懂,适合新手

    1. 概述 暗示效应告诉我们: 巧妙的暗示会在不知不觉中剥夺我们的判断力,对我们的思维形成一定的影响,造成我们行为的些许改变或者偏差. 例如你的朋友说你脸色不太好,是不是病了,此时,你可能就会感觉浑身 ...

  6. VUE3 之 使用标签实现动画与过渡效果 - 这个系列的教程通俗易懂,适合新手

    1. 概述 巴纳姆效应告诉我们: 人们更容易相信笼统的.常见的人格描述,并觉得特别适合自己,认为该描述真实地反映了自己的人格面貌. 这也是所有算命先生的小把戏,算命先生通常把话说的很笼统,很通用,基本 ...

  7. VUE3 之 使用标签实现动画与过渡效果(下) - 这个系列的教程通俗易懂,适合新手

    1. 概述 毛毛虫效应: 有这样一个实验,将许多毛毛虫放在一个花盆边缘,使它们首尾相接,围成一个圈.然后在离花盆很近的地方撒了一些毛毛虫的食物. 此时,毛毛虫并不会向食物的方向爬去,而是在花盆边缘,一 ...

  8. VUE3 之 多个元素之间的过渡 - 这个系列的教程通俗易懂,适合新手

    1. 概述 老话说的好:过去不等于未来,过去成功了不代表将来也会成功,过去失败了也不代表将来也会失败. 言归正传,今天我们聊聊多个元素之间的过渡. 2. 多个元素之间的过渡 2.1 两个元素交替显示 ...

  9. VUE3 之 列表动画 - 这个系列的教程通俗易懂,适合新手

    1. 概述 老话说的好:可以为别人解决痛点的产品就是好产品. 言归正传,今天我们来聊聊 VUE 的列表动画. 2. 列表动画 2.1  列表中增加和删除元素 <style> .my-ite ...

随机推荐

  1. vue中另一种路由写法

    一个项目中一级菜单是固定的,二级及其以下的菜单是动态的,直接根据文件夹结构写路由 import Vue from 'vue' import Router from 'vue-router' impor ...

  2. Linux驱动实践:中断处理函数如何【发送信号】给应用层?

    作 者:道哥,10+年嵌入式开发老兵,专注于:C/C++.嵌入式.Linux. 关注下方公众号,回复[书籍],获取 Linux.嵌入式领域经典书籍:回复[PDF],获取所有原创文章( PDF 格式). ...

  3. py3nvml实现GPU相关信息读取

    技术背景 随着模型运算量的增长和硬件技术的发展,使用GPU来完成各种任务的计算已经渐渐成为算法实现的主流手段.而对于运行期间的一些GPU的占用,比如每一步的显存使用率等诸如此类的信息,就需要一些比较细 ...

  4. 【代码优化】Bean映射之MapStruct

    [代码优化]Bean映射之MapStruct 一.背景 领域模型相互转换就只能靠手工的 get()/set()? 普遍的做法有以下几种: 手工 get()/set(): 构造器: BeanUtils ...

  5. python实现--九九乘法表

    1 for i in range(1,10): 2 for j in range(1,i+1): 3 print("%d*%d=%d"%(j,i,j*i),end="\t ...

  6. 论文解读二代GCN《Convolutional Neural Networks on Graphs with Fast Localized Spectral Filtering》

    Paper Information Title:Convolutional Neural Networks on Graphs with Fast Localized Spectral Filteri ...

  7. Jetpack—LiveData组件的缺陷以及应对策略 转至元数据结尾

    一.前言 为了解决Android-App开发以来一直存在的架构设计混乱的问题,谷歌推出了Jetpack-MVVM的全家桶解决方案.作为整个解决方案的核心-LiveData,以其生命周期安全,内存安全等 ...

  8. Cesium中级教程2 - 图层

    Cesium中文网:http://cesiumcn.org/ | 国内快速访问:http://cesium.coinidea.com/ Cesium支持从几个标准服务绘制和添加高分辨率图像(地图)图层 ...

  9. protobuf详解

    protobuf的基本类型和默认值,python中的小坑 标量数值类型 标量消息字段可以具有以下类型之一--该表显示了.原型文件,以及自动生成类中的对应类型: 默认值 python操作的坑 目录结构 ...

  10. Edge 91以上554、10080出现ERR_UNSAFE_PORT解决办法

    解决办法 在注册表下面这个路径新建一个键值名为1的,输入10080(或554),重启浏览器,即可解决问题. 计算机\HKEY_LOCAL_MACHINE\SOFTWARE\Policies\Micro ...