【愚公系列】《循序渐进Vue.js 3.x前端开发实践》029-组件的数据注入

news2025/1/31 5:42:29
标题详情
作者简介愚公搬代码
头衔华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,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:用于创建响应式数据。

  • provideinject:这两个函数是 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>
    `
}
  • propsmy-list 组件接收一个名为 count 的 prop,类型为 Number,这是从父级传递过来的数据(在这个例子中为 5)。

  • setup(props):Vue 3 的 Composition API 中的 setup 函数,用来处理组件逻辑。接收到 props 之后,调用 provideprops.count(即 5)以 listCount 为 key 提供给所有的后代组件。

    • provide("listCount", props.count):将 count 提供给子组件及其后代组件。在后续的子组件中,其他组件可以通过 inject 来访问这个值。
  • templatemy-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>
    `
}
  • propsmy-item 接收一个名为 index 的 prop,这个值是由父组件(my-list)通过 v-for 循环传递的,代表当前 my-item 组件的序号(例如,1、2、3、4、5)。
  • templatemy-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>
    `
}
  • propsmy-label 组件接收一个名为 index 的 prop,这个 index 是从 my-item 传递过来的。

  • setup():在 setup 函数中,my-label 组件通过 inject("listCount") 注入了由 my-list 组件提供的 listCount 数据。这个数据是父组件 my-listcount 的值(即 5),并将其作为响应式数据提供给模板。

  • template:模板中展示了当前 indexmy-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.代码逻辑总结

  1. 数据提供与注入:

    • 父组件 my-list 通过 providecount 属性提供给了所有的子组件及其后代组件,关键字是 "listCount"
    • 子组件 my-item 接收一个 index 并渲染 my-label 组件。
    • 深层子组件 my-label 使用 inject 获取了父组件通过 provide 提供的 listCount,从而获取了 count 的值(即 5)。
  2. 组件渲染:

    • my-list 组件会渲染若干个 my-item 组件,循环的次数是 count(即 5),每个 my-item 组件会传递一个 index 值。
    • 每个 my-item 组件会渲染一个 my-label 组件,并将 index 传递给它。
    • my-label 中,展示了 indexlistCount 的值(如 1/5, 2/5, 3/5 等)。
  3. Vue 3 provideinject 的使用:

    • provideinject 使得父组件和子组件之间可以通过这种依赖注入的方式传递数据,无需通过 props 一层一层地传递。这在组件层级较深时特别有用,减少了 prop 的传递复杂性。

🔎5.最终效果

  • 页面中会显示 5 个嵌套的组件,每个 my-item 组件显示一个 my-label,例如:
    • 1/5
    • 2/5
    • 3/5
    • 4/5
    • 5/5

在这里插入图片描述

🔎6.总结

这段代码展示了 Vue 3 中如何使用 provideinject 实现跨组件的数据共享。通过这种方式,父组件的数据可以被嵌套的深层子组件访问到,从而避免了层层传递 props 的复杂性。provide 提供数据,inject 注入数据,两者结合使用能够更加灵活地管理组件间的依赖。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2285137.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Redis学习之哨兵二

一、API 1.sentinel masters:展示被监控的主节点状态及相关的统计信息 2.sentinel master <master name>:展示指定的主节点的状态以及相关的统计信息 3.sentinel slaves <master name>:展示指定主节点的从节点状态以及相关的统计信息 4.sentinel sentinels <mas…

【Linux基础指令】第二期

本期博客的主题依旧是 "基础指令" &#xff1b; 上一期的基础指令链接&#xff1a; 【Linux基础指令】第一期-CSDN博客 &#xff0c;话不多说&#xff0c;正文开始&#xff1a; 一、Linux的指令 1.cp 拷贝功能&#xff1a; cp [stc] [dest] # 将 src文件 拷贝到…

MySQL(表空间)

​开始前先打开此图配合食用 MySQL表空间| ProcessOn免费在线作图,在线流程图,在线思维导图 InnoDB 空间文件中的页面管理 后面也会持续更新&#xff0c;学到新东西会在其中补充。 建议按顺序食用&#xff0c;欢迎批评或者交流&#xff01; 缺什么东西欢迎评论&#xff01;我都…

C26.【C++ Cont】动态内存管理和面向对象的方式实现链表

&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;除夕篇&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8;&#x1f9e8; 目录 1.知识回顾…

求解旅行商问题的三种精确性建模方法,性能差距巨大

文章目录 旅行商问题介绍三种模型对比求解模型1决策变量目标函数约束条件Python代码 求解模型2决策变量目标函数约束条件Python代码 求解模型3决策变量目标函数约束条件Python代码 三个模型的优势与不足 旅行商问题介绍 旅行商问题 (Traveling Salesman Problem, TSP) 是一个经…

C++:多继承习题3

题目内容&#xff1a; 声明一个时间类Time&#xff0c;时间类中有3个私有数据成员(Hour&#xff0c;Minute&#xff0c;Second)和两个公有成员函数(SetTime和PrintTime)。要求&#xff1a; &#xff08;1&#xff09; SetTime根据传递的3个参数为对象设置时间&#xff1b; &a…

低代码系统-产品架构案例介绍、得帆云(八)

产品名称 得帆云DeCode低代码平台-私有化 得帆云DeMDM主数据管理平台 得帆云DeCode低代码平台-公有云 得帆云DePortal企业门户 得帆云DeFusion融合集成平台 得帆云DeHoop数据中台 名词 概念 云原生 指自己搭建的运维平台&#xff0c;区别于阿里云、腾讯云 Dehoop 指…

【Unity3D】实现Decal贴花效果,模拟战旗游戏地形效果

目录 一、基础版 二、Post Process 辉光Bloom效果 矩形渐隐 涉及知识点&#xff1a;Decal贴花、屏幕后处理Bloom、屏幕空间构建世界空间、ChracterController物体移动、Terrain地形创建 一、基础版 Unity 2019.4.0f1 普通渲染管线&#xff08;非URP、非HDRP&#xff09; UR…

实践网络安全:常见威胁与应对策略详解

&#x1f4dd;个人主页&#x1f339;&#xff1a;一ge科研小菜鸡-CSDN博客 &#x1f339;&#x1f339;期待您的关注 &#x1f339;&#x1f339; 引言 在数字化转型的浪潮中&#xff0c;网络安全的重要性已达到前所未有的高度。无论是个人用户、企业&#xff0c;还是政府机构…

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是什么&#xff1f; Umami是一个开源项目&#xff0c;简单、快速、专注用户隐私的网站统计项目。 下面来介绍如何本地安装部署Umami项目&#xff0c;进行你的网站统计接入。特别对于首次使用docker的萌新有非常好的指导、参考和帮助作用。 Umami的github和docker镜像地…

KIMI K1.5:用大语言模型扩展强化学习(论文翻译)

文章目录 KIMI K1.5技术报告摘要 1. 引言2. 方法&#xff1a;基于大语言模型的强化学习2.1 强化学习提示集整理2.2 长思维链监督微调2.3 强化学习2.3.1 问题设定2.3.2 策略优化2.3.3 长度惩罚2.3.4 采样策略2.3.5 训练方法的更多细节 2.4 长到短&#xff1a;短思维链模型的上下…

思科交换机telnet配置案例

目录 1.telnet简述2.网络拓扑3.设备说明4.网络配置4.1 电脑PC ip设置4.2 网络交换机telnet配置 5.小结 1.telnet简述 Telnet是远程登录服务的一个协议&#xff0c;该协议定义了远程登录用户与服务器交互的方式。它允许用户在一台联网的计算机上登录到一个远程分时系统中&#…

计算机毕业设计Django+Tensorflow音乐推荐系统 机器学习 深度学习 音乐可视化 音乐爬虫 知识图谱 混合神经网络推荐算法 大数据毕设

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…

基于蓝牙6.0的RSSI和UWB融合定位方法,可行性分析

融合RSSI&#xff08;接收信号强度指示&#xff09;和UWB&#xff08;超宽带&#xff09;两种技术进行蓝牙6.0定位是完全可行的&#xff0c;并且可以带来更高的定位精度和稳定性。本文给出分析和MATLAB仿真结果 文章目录 技术优势RSSIUWB融合的优势 实现方案数据融合算法硬件要…

【开源免费】基于Vue和SpringBoot的在线文档管理系统(附论文)

本文项目编号 T 038 &#xff0c;文末自助获取源码 \color{red}{T038&#xff0c;文末自助获取源码} T038&#xff0c;文末自助获取源码 目录 一、系统介绍二、演示录屏三、启动教程四、功能截图五、文案资料5.1 选题背景5.2 国内外研究现状5.3 可行性分析 六、核心代码6.1 查…

AI DeepSeek

DeepSeek 文字解析 上传图片解析 视乎结果出入很大啊&#xff0c;或许我们应该描述更加清楚自己的需求。

QT使用eigen

QT使用eigen 1. 下载eigen https://eigen.tuxfamily.org/index.php?titleMain_Page#Download 下载后解压 2. QT引入eigen eigen源码好像只有头文件&#xff0c;因此只需要引入头文件就好了 qt新建项目后。修改pro文件. INCLUDEPATH E:\222078\qt\eigen-3.4.0\eigen-3.…

mysql学习笔记-数据库其他调优策略

1、如何定位调优问题 用户的反馈&#xff08;主要&#xff09; 日志分析&#xff08;主要&#xff09; 服务器资源使用监控 数据库内部状况监控 2、调优的维度和步骤 第1步&#xff1a;选择适合的 DBMS 第2步&#xff1a;优化表设计 第3步&#xff1a;优化逻辑查询 第4步&am…

HTB:Forest[WriteUP]

连接至HTB服务器并启动靶机 分配IP&#xff1a;10.10.16.21 靶机IP&#xff1a;10.10.10.161 靶机Domain&#xff1a;forest.htb 目录 连接至HTB服务器并启动靶机 信息收集 使用rustscan对靶机TCP端口进行开放扫描 将靶机TCP开放端口号提取并保存 使用nmap对靶机TCP开放端…