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

Vue3基础知识:组合式API中的provide和inject,他们作用是什么?如何使用?以及案例演示

1.provide和inject相较于父子传递的不同在于provide,inject可以用于跨层级通信(通俗易懂的讲就是可以实现爷孙之间的直接信息传递)。

1.跨层级传递数据

1.在顶层组件通过provide函数提供数据

2.底层组件通过inject函数获取数据

演示一:跨层传递普通数据。

效果图:

 

 

演示二:跨层传递动态数据。 

 

 效果图:

3.最后附上源代码:

爷爷组件App.vue
<script setup>
import Father from './components/Father.vue';
import { provide ,ref} from 'vue';//传递普通数据
provide('HairColor','black')//传递相应式数据
const count=ref(100)
provide('count',count)//跨层级传递函数
provide('changeCount',(SonInfo)=>{count.value--console.log(SonInfo)
})
</script><template><div><h1>这个是爷爷</h1><father></father></div>
</template><style lang="scss" scoped></style>
父亲组件Father.vue
<script setup>
import Son from './Son.vue';
</script><template><div><h2>这里是爸爸</h2><Son></Son></div>
</template><style lang="scss" scoped></style>
 孙子组件Son.vue
<script setup>
import { inject } from 'vue';
const HairColor=inject('HairColor')//
const count=inject('count')const ChangeCount=inject('changeCount')
const clickFn=()=>{ChangeCount('传给父亲的数据')
}
</script><template><div><h3>这里是儿子---爷爷头发的颜色---{{HairColor}} 年龄为:{{count}}岁</h3><button @click="clickFn">年龄减一</button></div>
</template><style lang="scss" scoped></style>

 

http://www.lryc.cn/news/393839.html

相关文章:

  • Transformer自注意力机制(Self-Attention)模型
  • 【计算机体系结构】缓存的false sharing
  • Ubuntu24.04 Isaacgym的安装
  • docker 设置代理,通过代理服务器拉取镜像
  • OpenCV教程02:图像处理系统1.0(翻转+形态学+滤波+缩放+旋转)
  • 人工智能在招投标领域的运用---监控视频连续性检测
  • 加装德国进口高精度主轴 智能手机壳「高质量高效率」钻孔铣槽
  • Java Stream API 常用操作技巧
  • SwiftData 模型对象的多个实例在 SwiftUI 中不能及时同步的解决
  • Android 系统网络、时间服务器配置修改
  • 类和对象深入理解
  • 在postgres数据库中的几个简单用法
  • SQLServer Manager Studio扩展开发从入门到弃坑
  • ComfyUI预处理器ControlNet简单介绍与使用(附件工作流)
  • 【篇三】在vue3上实现阿里云oss文件直传
  • OceanBase v4.2 特性解析:对Json与Xml的扩展支持
  • 《框架封装 · 统一异常处理和返回值包装》
  • 深入WebKit:揭秘复杂文档的高效渲染之道
  • 进程的控制-孤儿进程和僵尸进程
  • 【Unity navigation面板】
  • 二刷算法训练营Day53 | 动态规划(14/17)
  • 将缓冲文件写到磁盘中的命令sync
  • 灵活视图变换器:为扩散模型设计的革新图像生成架构
  • [终端安全]-1 总体介绍
  • Mysql5.7并发插入死锁问题
  • 网络“ping不通”,如何排查和解决呢?
  • 日常学习--20240706
  • 入门PHP就来我这(高级)12 ~ 获取数据
  • AIGC专栏12——EasyAnimateV3发布详解 支持图文生视频 最大支持960x960x144帧视频生成
  • 【python】python猫眼电影数据抓取分析可视化(源码+数据集+论文)【独一无二】