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. Microsoft HoloLens 开发(2): 运行Hello World

    1.下载 MixedRealityToolkit-Unity (混合现实工具包) 什么是 MixedRealityToolkit-Unity ? 一个脚本和组件的集合,加速针对微软全息和Windows ...

  2. [ vue ] 监听v-model数据的变化,只要有变化就改变vuex的state值

    场景描述: 1. 注册弹出框是用 v-model 绑定数据  showRegisterModal  实现的,点击遮罩层框架会把  showRegisterModal=false 2.REGISTER按 ...

  3. Linux上天之路(七)之Vim编辑器

    vim 是 "vimsual interface IMproved"的简称,它可以执行输出.删除.查找.替换.块操作等众多文本操作,而且用户可以根据自己的需要对其进行定制,这是其他 ...

  4. java集合【13】——— Stack源码分析走一波

    前言 集合源码分析系列:Java集合源码分析 前面已经把Vector,ArrayList,LinkedList分析完了,本来是想开始Map这一块,但是看了下面这个接口设计框架图:整个接口框架关系如下( ...

  5. 【Java】回形数

    回形数 键盘读入一个整数n(1-20),以n为矩阵大小,把1,2,3,4,5-按顺时针螺旋的形式填入. import java.util.Scanner; public class HuiXingSh ...

  6. Spring系列2:Spring容器基本概念和使用

    本文内容 简单回顾IoC和DI概念 Spring容器的概念 的xml配置和初始化 容器的基本使用 bean的定义和初始化配置 简单理解IoC和DI概念 什么是IoC控制反转? 通俗地但不严谨地讲,以前 ...

  7. Solon Web 开发,四、请求上下文

    Solon Web 开发 一.开始 二.开发知识准备 三.打包与运行 四.请求上下文 五.数据访问.事务与缓存应用 六.过滤器.处理.拦截器 七.视图模板与Mvc注解 八.校验.及定制与扩展 九.跨域 ...

  8. javascript 获取<td>标签内的值。

    当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model). HTML DOM 模型被构造为对象的树. 通过可编程的对象模型,JavaScript 获得了足够的能力来 ...

  9. 新手如何入门linux,linux原来还可以这么学

    前言 在这个只有cangls和小白两人的小房间中,展开了一次关于学习方法的讨论. 小白:cangls啊,我想请教一个问题,您是如何记住那么多linux命令的. cangls:我啊,别人都看我的小电影, ...

  10. 科技爱好者周刊(第 174 期):全能程序员 vs 特长程序员

    这里记录每周值得分享的科技内容,周五发布. 本杂志开源(GitHub: ruanyf/weekly),欢迎提交 issue,投稿或推荐科技内容. 周刊讨论区的帖子<谁在招人?>,提供大量程 ...