【愚公系列】《循序渐进Vue.js 3.x前端开发实践》029-组件的数据注入
| 标题 | 详情 |
|---|---|
| 作者简介 | 愚公搬代码 |
| 头衔 | 华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,CSDN商业化专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主,腾讯云内容共创官,掘金优秀博主,亚马逊技领云博主,51CTO博客专家等。 |
| 近期荣誉 | 2022年度博客之星TOP2,2023年度博客之星TOP2,2022年华为云十佳博主,2023年华为云十佳博主,2024年华为云十佳博主等。 |
| 博客内容 | .NET、Java、Python、Go、Node、前端、IOS、Android、鸿蒙、Linux、物联网、网络安全、大数据、人工智能、U3D游戏、小程序等相关领域知识。 |
| 欢迎 | 👍点赞、✍评论、⭐收藏 |
文章目录
- 🚀前言
- 🚀一、组件的数据注入
- 🔎1.HTML 部分解析
- 🔎2.JavaScript 部分解析
- 🦋2.1 父组件:`my-list`
- 🦋2.2 子组件:`my-item`
- 🦋2.3 深层子组件:`my-label`
- 🔎3.组件注册与挂载
- 🔎4.代码逻辑总结
- 🔎5.最终效果
- 🔎6.总结
🚀前言
在现代前端开发中,组件化设计已成为构建复杂应用的主流方式,而数据管理则是组件开发中的关键环节。如何高效地在不同组件间传递和共享数据,直接影响到应用的性能和可维护性。Vue.js 提供了多种数据注入的方式,包括 Props、Vuex、Provide/Inject 等,使得数据流动更加灵活和高效。
本篇文章将深入探讨组件的数据注入机制,重点分析各种数据传递方式及其使用场景。我们将从基本的 Props 传递开始,逐步引入 Provide/Inject 机制以及 Vuex 状态管理,帮助你理解何时使用哪种方法最为合适。此外,我们还将结合实际案例,展示如何在复杂应用中有效地组织和管理数据流。
🚀一、组件的数据注入
🔎1.HTML 部分解析
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Vue组件数据注入</title><script src="https://unpkg.com/vue@3/dist/vue.global.js"></script><style> * { }</style>
</head>
<body><div id="Application"><my-list :count="5"></my-list></div><script>...</script>
</body>
</html>
<div id="Application">:这是 Vue 应用的挂载容器,Vue 会将应用渲染到这个容器内。<my-list :count="5"></my-list>:这是父组件my-list,通过:count="5"向my-list组件传递了count属性,值为5。
🔎2.JavaScript 部分解析
const { createApp, ref, provide, inject } = Vue
const App = createApp({})
-
createApp({}):创建了一个 Vue 应用实例App,该实例不指定根组件,而是用来注册和管理其他组件。 -
ref:用于创建响应式数据。 -
provide和inject:这两个函数是 Vue 3 中的响应式依赖注入机制,允许在组件层级之间传递数据。
🦋2.1 父组件:my-list
const listCom = {props: {count: Number},setup(props) {provide("listCount", props.count)},template: `<div style="border:red solid 10px;"><my-item v-for="i in this.count" :index="i"></my-item></div>`
}
-
props:my-list组件接收一个名为count的 prop,类型为Number,这是从父级传递过来的数据(在这个例子中为5)。 -
setup(props):Vue 3 的 Composition API 中的setup函数,用来处理组件逻辑。接收到props之后,调用provide将props.count(即5)以listCount为 key 提供给所有的后代组件。provide("listCount", props.count):将count提供给子组件及其后代组件。在后续的子组件中,其他组件可以通过inject来访问这个值。
-
template:my-list组件的模板部分。它渲染了若干个my-item组件,其中v-for="i in this.count"循环渲染count数量的my-item组件,并通过:index="i"将当前循环的索引传递给my-item组件。
🦋2.2 子组件:my-item
const itemCom = {props: {index: Number},template: `<div style="border:blue solid 10px;"><my-label :index="this.index"></my-label></div>`
}
props:my-item接收一个名为index的 prop,这个值是由父组件(my-list)通过v-for循环传递的,代表当前my-item组件的序号(例如,1、2、3、4、5)。template:my-item渲染了my-label组件,并通过:index="this.index"将index传递给my-label。
🦋2.3 深层子组件:my-label
const labelCom = {props: {index: Number},setup() {const listCount = inject("listCount")return { listCount }},template: `<div>{{index}}/{{this.listCount}}</div>`
}
-
props:my-label组件接收一个名为index的 prop,这个index是从my-item传递过来的。 -
setup():在setup函数中,my-label组件通过inject("listCount")注入了由my-list组件提供的listCount数据。这个数据是父组件my-list中count的值(即5),并将其作为响应式数据提供给模板。 -
template:模板中展示了当前index(my-item组件的序号)和listCount(从父组件传递下来的count,即5)。- 例如,对于
index为 1 的my-label组件,模板会显示1/5,对于index为 2 的my-label组件,模板会显示2/5,依此类推。
- 例如,对于
🔎3.组件注册与挂载
App.component("my-list", listCom)
App.component("my-item", itemCom)
App.component("my-label", labelCom)
App.mount("#Application")
App.component("my-list", listCom):将my-list组件注册到 Vue 应用中。App.component("my-item", itemCom):将my-item组件注册到 Vue 应用中。App.component("my-label", labelCom):将my-label组件注册到 Vue 应用中。App.mount("#Application"):将 Vue 应用挂载到id="Application"的 DOM 元素上。
🔎4.代码逻辑总结
-
数据提供与注入:
- 父组件
my-list通过provide将count属性提供给了所有的子组件及其后代组件,关键字是"listCount"。 - 子组件
my-item接收一个index并渲染my-label组件。 - 深层子组件
my-label使用inject获取了父组件通过provide提供的listCount,从而获取了count的值(即5)。
- 父组件
-
组件渲染:
my-list组件会渲染若干个my-item组件,循环的次数是count(即5),每个my-item组件会传递一个index值。- 每个
my-item组件会渲染一个my-label组件,并将index传递给它。 - 在
my-label中,展示了index和listCount的值(如1/5,2/5,3/5等)。
-
Vue 3
provide和inject的使用:provide和inject使得父组件和子组件之间可以通过这种依赖注入的方式传递数据,无需通过props一层一层地传递。这在组件层级较深时特别有用,减少了 prop 的传递复杂性。
🔎5.最终效果
- 页面中会显示 5 个嵌套的组件,每个
my-item组件显示一个my-label,例如:1/52/53/54/55/5

🔎6.总结
这段代码展示了 Vue 3 中如何使用 provide 和 inject 实现跨组件的数据共享。通过这种方式,父组件的数据可以被嵌套的深层子组件访问到,从而避免了层层传递 props 的复杂性。provide 提供数据,inject 注入数据,两者结合使用能够更加灵活地管理组件间的依赖。
相关文章:
【愚公系列】《循序渐进Vue.js 3.x前端开发实践》029-组件的数据注入
标题详情作者简介愚公搬代码头衔华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,CSDN商业化专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主&…...
Redis学习之哨兵二
一、API 1.sentinel masters:展示被监控的主节点状态及相关的统计信息 2.sentinel master <master name>:展示指定的主节点的状态以及相关的统计信息 3.sentinel slaves <master name>:展示指定主节点的从节点状态以及相关的统计信息 4.sentinel sentinels <mas…...
【Linux基础指令】第二期
本期博客的主题依旧是 "基础指令" ; 上一期的基础指令链接: 【Linux基础指令】第一期-CSDN博客 ,话不多说,正文开始: 一、Linux的指令 1.cp 拷贝功能: cp [stc] [dest] # 将 src文件 拷贝到…...
SpringBoot的细节问题
一、重点填空 Pivotal 团队在原有 spring 框架的基础上开发了全新的Spring Boot框架。Spring Boot框架在开发过程中大量使用 约定优于配置 的思想来摆脱框架中各种复杂的手动配置。Spring Boot 2.1.3版本要求 Java 8 及以上版本的支持。Spring Boot2.1.3版本框架官方声明支持的…...
JavaScript系列(46)-- WebGL图形编程详解
JavaScript WebGL图形编程详解 🎨 今天,让我们深入探讨JavaScript的WebGL图形编程。WebGL是一种基于OpenGL ES的JavaScript API,它允许我们在浏览器中渲染高性能的2D和3D图形。 WebGL基础概念 🌟 💡 小知识ÿ…...
MySQL(表空间)
开始前先打开此图配合食用 MySQL表空间| ProcessOn免费在线作图,在线流程图,在线思维导图 InnoDB 空间文件中的页面管理 后面也会持续更新,学到新东西会在其中补充。 建议按顺序食用,欢迎批评或者交流! 缺什么东西欢迎评论!我都…...
C26.【C++ Cont】动态内存管理和面向对象的方式实现链表
🧨🧨🧨🧨🧨🧨🧨🧨🧨除夕篇🧨🧨🧨🧨🧨🧨🧨🧨🧨 目录 1.知识回顾…...
使用numpy自定义数据集 使用tensorflow框架实现逻辑回归并保存模型,然后保存模型后再加载模型进行预
1. 引言 逻辑回归(Logistic Regression)是一种常见的分类算法,广泛应用于二分类问题。在本篇博客中,我们将使用numpy生成一个简单的自定义数据集,并使用TensorFlow框架构建和训练逻辑回归模型。训练完成后,…...
Java Web 开发基础介绍
Java学习资料 Java学习资料 Java学习资料 一、引言 在当今数字化时代,Web 应用无处不在。Java 凭借其强大的功能、良好的跨平台性和丰富的开发框架,成为 Web 开发领域的热门选择之一。Java Web 开发允许开发者构建动态、交互式的 Web 应用程序&#x…...
求解旅行商问题的三种精确性建模方法,性能差距巨大
文章目录 旅行商问题介绍三种模型对比求解模型1决策变量目标函数约束条件Python代码 求解模型2决策变量目标函数约束条件Python代码 求解模型3决策变量目标函数约束条件Python代码 三个模型的优势与不足 旅行商问题介绍 旅行商问题 (Traveling Salesman Problem, TSP) 是一个经…...
C++:多继承习题3
题目内容: 声明一个时间类Time,时间类中有3个私有数据成员(Hour,Minute,Second)和两个公有成员函数(SetTime和PrintTime)。要求: (1) SetTime根据传递的3个参数为对象设置时间; &a…...
低代码系统-产品架构案例介绍、得帆云(八)
产品名称 得帆云DeCode低代码平台-私有化 得帆云DeMDM主数据管理平台 得帆云DeCode低代码平台-公有云 得帆云DePortal企业门户 得帆云DeFusion融合集成平台 得帆云DeHoop数据中台 名词 概念 云原生 指自己搭建的运维平台,区别于阿里云、腾讯云 Dehoop 指…...
python Flask-Redis 连接远程redis
当使用Flask-Redis连接远程Redis时,首先需要安装Flask-Redis库。可以通过以下命令进行安装: pip install Flask-Redis然后,你可以使用以下示例代码连接远程Redis: from flask import Flask from flask_redis import FlaskRedisa…...
【Unity3D】实现Decal贴花效果,模拟战旗游戏地形效果
目录 一、基础版 二、Post Process 辉光Bloom效果 矩形渐隐 涉及知识点:Decal贴花、屏幕后处理Bloom、屏幕空间构建世界空间、ChracterController物体移动、Terrain地形创建 一、基础版 Unity 2019.4.0f1 普通渲染管线(非URP、非HDRP) UR…...
实践网络安全:常见威胁与应对策略详解
📝个人主页🌹:一ge科研小菜鸡-CSDN博客 🌹🌹期待您的关注 🌹🌹 引言 在数字化转型的浪潮中,网络安全的重要性已达到前所未有的高度。无论是个人用户、企业,还是政府机构…...
《 C++ 点滴漫谈: 二十四 》深入 C++ 变量与类型的世界:高性能编程的根基
摘要 本文深入探讨了 C 中变量与类型的方方面面,包括变量的基本概念、基本与复合数据类型、动态类型与内存管理、类型推导与模板支持,以及类型系统的高级特性。通过全面的理论讲解与实际案例分析,展示了 C 类型系统的强大灵活性与实践价值。…...
UART、I2C和SPI对比
UARTSPII2C英文Universal Asynchronous Receive/TransmitSerial Peripheral InterfaceInner Integrated Communication通讯速度115200、38400 bit/s高达100M bit/s 100k、400k、1M、3.4M bit/s时钟同/异步性时钟异步时钟同步时钟同步接线方式3线(Rx、Tx、GND) 4线(MISO、…...
开源项目Umami网站统计MySQL8.0版本Docker+Linux安装部署教程
Umami是什么? Umami是一个开源项目,简单、快速、专注用户隐私的网站统计项目。 下面来介绍如何本地安装部署Umami项目,进行你的网站统计接入。特别对于首次使用docker的萌新有非常好的指导、参考和帮助作用。 Umami的github和docker镜像地…...
C# INotifyPropertyChanged接口在list类型中的应用
我们在项目开发时遇到监听List<T>中成员的值发生变化。我们一般使用INotifyPropertyChanged...
KIMI K1.5:用大语言模型扩展强化学习(论文翻译)
文章目录 KIMI K1.5技术报告摘要 1. 引言2. 方法:基于大语言模型的强化学习2.1 强化学习提示集整理2.2 长思维链监督微调2.3 强化学习2.3.1 问题设定2.3.2 策略优化2.3.3 长度惩罚2.3.4 采样策略2.3.5 训练方法的更多细节 2.4 长到短:短思维链模型的上下…...
Kiwi 安卓浏览器本月停止维护,扩展功能迁移至 Edge Canary
IT之家 1 月 25 日消息,科技媒体 Android Authority 今天(1 月 25 日)发布博文,报道称 Kiwi 安卓浏览器将于本月停止维护,相关扩展支持功能已整合到微软 Edge Canary 浏览器中。 开发者 Arnaud42 表示 Kiwi 安卓浏览器…...
思科交换机telnet配置案例
目录 1.telnet简述2.网络拓扑3.设备说明4.网络配置4.1 电脑PC ip设置4.2 网络交换机telnet配置 5.小结 1.telnet简述 Telnet是远程登录服务的一个协议,该协议定义了远程登录用户与服务器交互的方式。它允许用户在一台联网的计算机上登录到一个远程分时系统中&#…...
计算机毕业设计Django+Tensorflow音乐推荐系统 机器学习 深度学习 音乐可视化 音乐爬虫 知识图谱 混合神经网络推荐算法 大数据毕设
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
基于蓝牙6.0的RSSI和UWB融合定位方法,可行性分析
融合RSSI(接收信号强度指示)和UWB(超宽带)两种技术进行蓝牙6.0定位是完全可行的,并且可以带来更高的定位精度和稳定性。本文给出分析和MATLAB仿真结果 文章目录 技术优势RSSIUWB融合的优势 实现方案数据融合算法硬件要…...
【开源免费】基于Vue和SpringBoot的在线文档管理系统(附论文)
本文项目编号 T 038 ,文末自助获取源码 \color{red}{T038,文末自助获取源码} T038,文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 查…...
【Elasticsearch】 索引模板 ignore_missing_component_templates
解释 ignore_missing_component_templates 配置 在Elasticsearch中,ignore_missing_component_templates 是一个配置选项,用于处理索引模板中引用的组件模板可能不存在的情况。当您创建一个索引模板时,可以指定一个或多个组件模板࿰…...
AI DeepSeek
DeepSeek 文字解析 上传图片解析 视乎结果出入很大啊,或许我们应该描述更加清楚自己的需求。...
QT使用eigen
QT使用eigen 1. 下载eigen https://eigen.tuxfamily.org/index.php?titleMain_Page#Download 下载后解压 2. QT引入eigen eigen源码好像只有头文件,因此只需要引入头文件就好了 qt新建项目后。修改pro文件. INCLUDEPATH E:\222078\qt\eigen-3.4.0\eigen-3.…...
C#面试常考随笔6:ArrayList和 List的主要区别?
在 C# 中,ArrayList和List<T>(泛型列表)都可用于存储一组对象。推荐优先使用List<T>,因为它具有更好的类型安全性、性能和语法简洁性,并且提供了更丰富的功能。只有在需要与旧代码兼容或存储不同类型对象的…...
mysql学习笔记-数据库其他调优策略
1、如何定位调优问题 用户的反馈(主要) 日志分析(主要) 服务器资源使用监控 数据库内部状况监控 2、调优的维度和步骤 第1步:选择适合的 DBMS 第2步:优化表设计 第3步:优化逻辑查询 第4步&am…...
