当前位置: 首页 > news >正文

<Vue>使用依赖注入的方式共享数据

什么是vue依赖注入?

Vue是一个用于构建用户界面的渐进式框架。

它提供了一种简单而灵活的方式来管理组件之间的数据流,即依赖注入(Dependency Injection,DI)。

依赖注入是一种设计模式,它允许一个组件从另一个组件获取它所依赖的数据或服务,而不需要自己创建或管理它们。这样可以降低组件之间的耦合度,提高代码的可维护性和可测试性。

依赖注入示意图

在这里插入图片描述

provide和inject

在Vue中,依赖注入的方式是通过provide和inject两个选项来实现的。

provide选项允许一个祖先组件向下提供数据或服务给它的所有后代组件。
inject选项允许一个后代组件接收来自祖先组件的数据或服务。
这两个选项都可以是一个对象或一个函数,对象的键是提供或接收的数据或服务的名称,值是对应的数据或服务。函数的返回值是一个对象,具有相同的格式。

下面是一个简单的例子,演示了如何使用依赖注入的方式共享数据:

父组件

<template><div><h1>我是祖先组件</h1><child-component></child-component></div>
</template>
<script>
import ChildComponent from './ChildComponent.vue'export default {name: 'AncestorComponent',components: {ChildComponent},// 提供一个名为message的数据provide: {message: 'Hello from ancestor'}
}
</script>

子组件

<template><div><h2>我是后代组件</h2><p>{{ message }}</p></div>
</template>
// 后代组件
<script>
export default {name: 'ChildComponent',// 接收一个名为message的数据inject: ['message']
}
</script>

这样,后代组件就可以直接使用祖先组件提供的数据,而不需要通过props或事件来传递。

需要注意的是,依赖注入的数据是不可响应的,也就是说,如果祖先组件修改了提供的数据,后代组件不会自动更新。
如果需要实现响应性,可以使用一个响应式的对象或者一个返回响应式对象的函数作为provide的值。

实现响应式依赖注入的几种方式

在这里插入图片描述

一、提供响应式数据

方法是在提供者组件中使用ref或reactive创建响应式数据,然后通过provide提供给后代组件。后代组件通过inject接收后,就可以响应数据的变化。

提供者:

<template><div><h1>我是提供者组件</h1><button @click="count++">增加计数</button><child-component></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue'
import { ref, provide } from 'vue'export default {name: 'ProviderComponent',components: {ChildComponent},setup() {// 使用ref创建一个响应式的计数器const count = ref(0)// 提供给后代组件provide('count', count)return {count}}
}
</script>

接收者:

<template><div><h2>我是接收者组件</h2><p>计数器的值是:{{ count }}</p></div>
</template><script>
import { inject } from 'vue'export default {name: 'ChildComponent',setup() {// 接收提供者组件提供的响应式对象const count = inject('count')return {count}}
}
</script>

二、提供修改数据的方法

提供者组件可以提供修改数据的方法函数,接收者组件调用该方法来更改数据,而不是直接修改注入的数据。

提供者:

<template><div><h1>我是提供者组件</h1><p>消息是:{{ message }}</p><child-component></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue'
import { ref, provide } from 'vue'export default {name: 'ProviderComponent',components: {ChildComponent},setup() {// 使用ref创建一个响应式的消息const message = ref('Hello')// 定义一个更改消息的方法function updateMessage() {message.value = 'Bye'}// 提供给后代组件provide('message', { message, updateMessage })return {message}}
}
</script>

接收者:

<template><div><h2>我是接收者组件</h2><p>消息是:{{ message }}</p><button @click="updateMessage">更改消息</button></div>
</template><script>
import { inject } from 'vue'export default {name: 'ChildComponent',setup() {// 接收提供者组件提供的响应式对象和方法const { message, updateMessage } = inject('message')return {message,updateMessage}}
}
</script>

三、使用readonly包装

通过readonly包装provide的数据,可以防止接收者组件修改数据,保证数据流的一致性。

提供者:

<template><div><h1>我是提供者组件</h1><p>姓名是:{{ name }}</p><child-component></child-component></div>
</template><script>
import ChildComponent from './ChildComponent.vue'
import { ref, provide, readonly } from 'vue'export default {name: 'ProviderComponent',components: {ChildComponent},setup() {// 使用ref创建一个响应式的姓名const name = ref('Alice')// 使用readonly包装提供的值,使其不可修改provide('name', readonly(name))return {name}}
}
</script>

接收者:

<template><div><h2>我是接收者组件</h2><p>姓名是:{{ name }}</p><button @click="name = 'Bob'">尝试修改姓名</button></div>
</template><script>
import { inject } from 'vue'export default {name: 'ChildComponent',setup() {// 接收提供者组件提供的只读对象const name = inject('name')return {name}}
}
</script>

四、使用<script setup>

<script setup>组合式写法下,provide和inject默认就是响应式的,无需额外处理。

总结

在这里插入图片描述

依赖注入的方式共享数据在Vue中是一种高级特性,它主要用于开发插件或库,或者处理一些特殊的场景。

相关文章:

<Vue>使用依赖注入的方式共享数据

什么是vue依赖注入&#xff1f; Vue是一个用于构建用户界面的渐进式框架。 它提供了一种简单而灵活的方式来管理组件之间的数据流&#xff0c;即依赖注入&#xff08;Dependency Injection&#xff0c;DI&#xff09;。 依赖注入是一种设计模式&#xff0c;它允许一个组件从另一…...

从0到1:腾讯云服务器使用教程

腾讯云服务器入门教程包括云服务器CPU内存带宽配置选择&#xff0c;选择云服务器CVM或轻量应用服务器&#xff0c;云服务器创建后重置密码、远程连接、搭建程序环境等&#xff0c;腾讯云服务器网txyfwq.com分享从0到1腾讯云服务器入门教程&#xff1a; 目录 腾讯云服务器入门…...

VScode + opencv + c++ + win配置教程

准备&#xff1a; 1、下载opencv 2、下载MinGw 3、 3、下载CMake 下载完解压放到一个文件夹里面&#xff0c;便于环境管理&#xff0c;文件夹我重命名了&#xff0c;解压出来文件名不一样正常 环境变量配置 C:\Users\wuxulong\cpp_env\MinGw\mingw64\bin C:\Users\wuxulon…...

机器学习---SVM目标函数求解,SMO算法

1. 线性可分支持向量机 1.1 定义输入数据 假设给定⼀个特征空间上的训练集为&#xff1a; 其中&#xff0c;(x , y )称为样本点。 x 为第i个实例&#xff08;样本&#xff09;。 y 为x 的标记&#xff1a; 当y 1时&#xff0c;x 为正例&#xff1b;当y −1时&#xff0c;x…...

044_第三代软件开发-保存PDF

第三代软件开发-保存PDF 文章目录 第三代软件开发-保存PDF项目介绍保存PDF头文件源文件使用 关键字&#xff1a; Qt、 Qml、 pdf、 painter、 打印 项目介绍 欢迎来到我们的 QML & C 项目&#xff01;这个项目结合了 QML&#xff08;Qt Meta-Object Language&#xff…...

2023红帽论坛:构建开放AI生态,助力企业数字革新之路

随着人工智能技术的飞速发展&#xff0c;各行各业正面临着一场前所未有的数字化转型浪潮。尤其是AIGC&#xff08;人工智能生成内容&#xff09;技术自2022年底以来的蓬勃兴起&#xff0c;不仅重塑了用户体验&#xff0c;也为企业运营带来了深刻的变革。 在这样的大背景下&…...

阿里云国际站和华为云国际站之间该如何选择?

阿里云国际站和华为云国际站都是知名的云计算服务提供商&#xff0c;它们各自具有一些独特的优势和劣势。以下是它们之间的一些对比&#xff0c;九河云根据不同的使用场景提供的建议&#xff1a; 阿里云国际站&#xff1a; 优势&#xff1a; 全球覆盖&#xff1a;阿里云国际…...

JavaScript设计模式之责任链模式

适用场景&#xff1a;一个完整的流程&#xff0c;中间分成多个环节&#xff0c;各个环节之间存在一定的顺序关系&#xff0c;同时中间的环节的个数不一定&#xff0c;可能添加环节&#xff0c;也可能减少环节&#xff0c;只要保证顺序关系就可以。 如下图&#xff1a; ES5写法…...

云安全—kubelet攻击面

0x00 前言 虽然说总结的是kubelet的攻击面&#xff0c;但是在总结攻击面之前还是需要去了解kubelet的基本原理&#xff0c;虽然说我们浅尝即止&#xff0c;但是还是要以能给别人讲出来为基本原则。 其他文章: 云安全—K8s APi Server 6443 攻击面云安全—K8S API Server 未授…...

leetcode经典面试150题---5.多数元素

目录 题目描述 前置知识 代码 方法一 排序法 思路 实现 复杂度 方法二 哈希表 思路 实现 题目描述 给定一个大小为 n 的数组 nums &#xff0c;返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。 你可以假设数组是非空的&#xff0c;并且给…...

Vue ElementUI el-tooltip 全局样式修改

el-tooltip 要点 此处是全局配置&#xff1b;如果想设置指定的 tooltip 可设置属性 popper-class&#xff0c;为 tooltip 的 popper 添加类名&#xff1b;代码 6 - 8 行&#xff0c;隐藏小三角&#xff1b; .el-tooltip__popper {border-radius: 4px !important;color: #9E9…...

MATLAB_5MW风电永磁直驱发电机-1200V直流并网MATLAB仿真模型

仿真软件&#xff1a;matlab2016b 风机传动模块、PMSG模块、蓄电池模块、超级电容模块、无穷大电源、蓄电池控制、风机控制、逆变器控制等模块。 逆变器输出电压&#xff1a; 混合储能系统SOC&#xff1a; 威♥关注“电击小子程高兴的MATLAB小屋”获取更多精彩资料&#xff0…...

11.4商业伦理(全)

大型工商业城市和小城市的商业伦理道德水平是否存在差异&#xff0c;如果有&#xff0c;存在哪些差异&#xff1f; 伦理道德对产业分工的影响 产业层级越高&#xff0c;需要的商业伦理道德水平越高 产业级别越高&#xff0c;利润率越高 去中心化的去信任化的比特币会不会取…...

【漏洞复现】S2-045 Remote Code Execution(CVE-2017-5638)

感谢互联网提供分享知识与智慧&#xff0c;在法治的社会里&#xff0c;请遵守有关法律法规 文章目录 1.1、漏洞描述1.2、漏洞等级1.3、影响版本1.4、漏洞复现1、基础环境2、漏洞扫描nacs3、漏洞验证 1.5、修复建议 说明内容漏洞编号CVE-2017-5638漏洞名称S2-045 远程代码执行漏…...

Linux----------------Shell重定向输入输出

&#xff08;一&#xff09; 标准输入 以键盘读取用户输入的数据&#xff0c;然后再把数据拿到 Shel程序中使用。 标准输出 Shell 程序产生的数据&#xff0c;这些数据一般都是呈现到显示器上供用户浏览查看 输入输出重定向 输入方向就是数据从哪里流向程序。数据默认从键…...

apachesolr中简单使用

core使用 首先点击add core 可以看到报错solrconfig.xml不在new_core目录下&#xff0c;new_core是我们点击后自动创建的 那么我们将D:\solr2\solr-9.3.0\solr-9.3.0\server\solr\configsets下的任何一个目录下的conf拷贝到new_core过去 这里是使用_default下的conf目录拷贝…...

C++多线程编程:其一、thread类概述

thread是C11版本中出现的线程对象&#xff0c;可以让程序员非常方便地创建线程。 非空的thread对象创建以后&#xff0c;线程就会自动运行起来。简单地理解&#xff0c;一个线程对象中会传入一个函数指针&#xff0c;之后编译器会构造一个栈&#xff0c;将这个函数指针压栈。函…...

C++11 initializer_list 轻量级初始化列表的使用场景(让自定义类可以用初始化列表的形式来实例化对象)

initializer_list 是 C11 中的一个特性&#xff0c;它允许你使用花括号 {} 中的值列表来初始化容器或数组。通常用于初始化标准库容器&#xff0c;比如 std::vector、std::set、std::map 以及数组。 场景一&#xff1a;用初始化列表初始化容器 std::vector<int> arr {…...

请求地址‘/operlog‘,发生未知异常

&#x1f468;&#x1f3fb;‍&#x1f4bb; 热爱摄影的程序员 &#x1f468;&#x1f3fb;‍&#x1f3a8; 喜欢编码的设计师 &#x1f9d5;&#x1f3fb; 擅长设计的剪辑师 &#x1f9d1;&#x1f3fb;‍&#x1f3eb; 一位高冷无情的编码爱好者 大家好&#xff0c;我是全栈工…...

Makefile 保姆级使用教程

目录 Makefile 规则 Makefile的使用介绍 make 命令的使用 即时变量、延时变量介绍和使用 使用make命令编译多个文件 假想目标 常用函数 1.$(foreach var,list,text) 2.$(wildcard pattern) 3.$(filter pattern...,text) 4.$(filter-out pattern...,text) 5.$(patsub…...

Rust错误处理最佳实践:从恐慌到优雅处理

Rust错误处理最佳实践&#xff1a;从恐慌到优雅处理 前言 大家好&#xff0c;我是第一程序员&#xff08;名字大&#xff0c;人很菜&#xff09;&#xff0c;一个正在跟Rust所有权和生命周期死磕的后端转Rust萌新。最近&#xff0c;我开始学习Rust的错误处理&#xff0c;发现…...

嵌入式IMU姿态解算:轻量级卡尔曼滤波器实现Pitch/Roll估计

1. 项目概述Kalman滤波器库是一个面向嵌入式姿态解算的轻量级C语言实现&#xff0c;专为资源受限的MCU&#xff08;如STM32F0/F1/F4系列、nRF52、ESP32等&#xff09;设计。其核心工程目标明确&#xff1a;在无磁力计辅助、仅依赖IMU原始数据&#xff08;加速度计陀螺仪&#x…...

如何用嘎嘎降AI处理文献综述部分:综述专项降AI教程

如何用嘎嘎降AI处理文献综述部分&#xff1a;综述专项降AI教程 这篇教程来自实操经验。帮三个同学处理过论文AI率&#xff0c;加上自己的&#xff0c;前后操作了十几次。把流程总结成教程&#xff0c;尽量详细。 核心工具推荐嘎嘎降AI&#xff08;www.aigcleaner.com&#xf…...

7张图讲透Claude Code架构(非常详细),Harness设计从入门到精通,收藏这一篇就够了!

1. 整体概述 众所周知&#xff0c;Claude Code不仅仅是Coding产品&#xff0c;更是一个通用的终端Agent&#xff1a;能循环思考、调度工具、治理权限、恢复上下文、稳定长会话… 如何研读项目源码呢&#xff1f; 首先&#xff0c;我让AI帮着梳理了下目录架构和模块职责&…...

OpCore-Simplify:黑苹果配置的智能革命——从手动调试到自动化生成的转变

OpCore-Simplify&#xff1a;黑苹果配置的智能革命——从手动调试到自动化生成的转变 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 传统黑苹果配置需…...

use Yii;的本质的庖丁解牛

use Yii; 这行代码&#xff0c;常被误解为“引入了一个类”或者“为了少打几个字”。 但本质上&#xff0c;它是 Yii 框架&#xff08;尤其是 Yii2&#xff09;架构哲学的“图腾”。 它标志着 Yii 选择了一条与 Laravel、Symfony 截然不同的道路&#xff1a;将核心功能暴露为一…...

告别手动敲命令:用Rancher 2.9.2的Web界面,5分钟搞定K8S 1.26集群的Nginx部署

告别手动敲命令&#xff1a;用Rancher 2.9.2的Web界面&#xff0c;5分钟搞定K8S 1.26集群的Nginx部署 在Kubernetes的世界里&#xff0c;部署一个简单的Nginx服务往往需要编写复杂的YAML文件&#xff0c;记忆各种kubectl命令参数&#xff0c;这对于刚接触K8S的开发者或小型运维…...

安卓手机玩PS1游戏全攻略:DuckStation模拟器0.1-8675版汉化+BIOS配置指南

安卓手机畅玩PS1经典游戏&#xff1a;DuckStation模拟器深度配置指南 还记得那些年在PlayStation上度过的美好时光吗&#xff1f;《最终幻想7》的史诗冒险、《合金装备》的紧张潜入、《生化危机》的惊悚体验&#xff0c;这些经典游戏如今都能在你的安卓手机上完美重现。DuckSta…...

新手零压力:快马ai带你编写第一份vmware虚拟机搭建图文指南

新手零压力&#xff1a;快马AI带你编写第一份VMware虚拟机搭建图文指南 作为一个刚接触编程的新手&#xff0c;搭建虚拟机环境往往是遇到的第一个挑战。记得我第一次尝试安装VMware时&#xff0c;面对各种专业术语和复杂的配置选项&#xff0c;完全不知道从何下手。好在现在有…...

28_关于交叉学科的学习方法

1、费曼学习法 1.1 概念费曼学习法是一种以"以教代学"为核心的高效学习方法&#xff0c;由诺贝尔物理学奖得主理查德费曼&#xff08;Richard Feynman&#xff09; 提出。理查德费曼&#xff08;1918-1988&#xff09;是美国著名的理论物理学家&#xff0c;1965年因在…...