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

vue3 #跨组件通信

//爷爷组件中

import { provide , ref } from 'vue'

const money = ref (100)       //定义数据

provide( 'money' , money )     //提供数据给孙子组件

const changeMoney = ( m:number ) => {      //定义函数

    if (money) {

       money.value = money.value - m

  }

}

provide("changeMoney ",changeMoney)    //提供函数给孙子组件

// 孙子组件中

import { inject } from 'vue'

const money = inject('money')     //获取传递过来的数据

const changeMoney = inject<m:number> => viod ('changeMoney ')  //获取传递过来的函数

举例:如果在孙子组件中想要修改爷爷组件的数据

// 孙子组件中

<button @click="handleMoney">

import { inject } from 'vue'

const money = inject< Ref<number> >('money')     //获取数据

const handleMoney=()=> {

    if(money) {            //在跨组件通信中,可能没有传值,所有这里做一个判断

         money.value += 2

  }

}

⭐inject函数会默认将数据定义为unknown,所以这里需要定义一下传过来数据的类型

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

相关文章:

  • 【AI绘画工具有哪些?】讲解
  • 在Vue中使用TypeScript时 props指定枚举类型
  • 快速将excel/word表格转换为web页面(html)的方法
  • 想高薪就业鸿蒙HarmonyOS 开发岗位,到底该学习些啥?
  • Java中的建造者模式
  • 机器学习面试:逻辑回归与朴素贝叶斯区别
  • 数据结构之线性表
  • 记录解决uniapp使用uview-plus在vue3+vite+ts项目中打包后样式不能显示问题
  • 三年功能测试,测试工作吐槽
  • 0206-1-网络层
  • 以 All-in-One 模式安装 KubeSphere时避坑
  • Android T 远程动画显示流程其二——动画的添加流程(更新中)
  • Pytorch-SGD算法解析
  • 物联网土壤传感器简介
  • MySQL索引面试题(高频)
  • SouthLeetCode-打卡24年02月第2周
  • Rust CallBack的几种写法
  • Redis突现拒绝连接问题处理总结
  • css中选择器的优先级
  • python3字符串内建方法split()心得
  • html的列表标签
  • 【Pytorch深度学习开发实践学习】B站刘二大人课程笔记整理lecture04反向传播
  • PyTorch使用Tricks:学习率衰减 !!
  • 10MARL深度强化学习 Value Decomposition in Common-Reward Games
  • 2 Nacos适配达梦数据库实现方案
  • 【Gitea】配置 Push To Create
  • 关于postgresql数据库单独设置某个用户日志级别(日志审计)
  • 阿里云ECS香港服务器性能强大、cn2高速网络租用价格表
  • 实战打靶集锦-025-HackInOS
  • list.stream().forEach()和list.forEach()的区别