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

父组件调用子组件方法(组合式 API版)

在 Vue 3 中,defineExpose 是一个用于在组合式 API (Composition API) 中暴露组件内部方法或属性的函数。它允许父组件通过 ref 引用子组件实例,并调用子组件暴露的方法或访问其属性。

以下是子组件和父组件如何使用 defineExposeref 的详细解释和示例。

子组件

子组件通过 defineExpose 来暴露方法,使父组件能够调用这些方法。

<!-- 子组件 SelectCase.vue -->
<template><a-modal v-model:visible="caseIsVisable"><!-- 模态框内容 --></a-modal>
</template><script setup>
import { ref } from 'vue';const caseIsVisable = ref(false);// 新增,打开模态框
const openModal = () => {caseIsVisable.value = true;
};// 取消,关闭模态框
const handleCancel = () => {caseIsVisable.value = false;
};// 暴露方法给父组件
defineExpose({openModal,handleCancel,
});
</script>

父组件

父组件通过 ref 引用子组件实例,并可以调用子组件暴露的方法。

<!-- 父组件 ParentComponent.vue -->
<template><SelectCase ref="selectCaseRef" :graphInfo="graphInfo" /><button @click="openChildModal">Open Modal in Child</button>
</template><script setup>
import { ref } from 'vue';
import SelectCase from './SelectCase.vue';const graphInfo = ref({}); // 示例数据// 引用子组件实例
const selectCaseRef = ref(null);// 调用子组件方法
const openChildModal = () => {selectCaseRef.value.openModal();
};
</script>

原理解释

  1. 子组件中的 defineExpose:

    • defineExpose 用于将子组件的某些方法或属性暴露给父组件。在这个例子中,openModalhandleCancel 方法通过 defineExpose 暴露。
    • 这样做的目的是让父组件能够调用这些方法来控制子组件的行为,比如打开或关闭模态框。
  2. 父组件中的 ref:

    • 在父组件中,通过 ref 引用子组件的实例。使用 ref 可以在父组件中直接访问子组件的方法和属性。
    • 例如,const selectCaseRef = ref(null); 创建一个引用来存储子组件实例。
    • 在模板中,通过 ref="selectCaseRef" 将子组件实例赋值给 selectCaseRef
  3. 调用子组件的方法:

    • 一旦子组件实例被引用到 selectCaseRef,父组件就可以通过 selectCaseRef.value 访问子组件的暴露方法。
    • selectCaseRef.value.openModal(); 调用子组件的 openModal 方法,从而在子组件中打开模态框。
http://www.lryc.cn/news/366826.html

相关文章:

  • 【动手学深度学习】使用块的网络(VGG)的研究详情
  • JFinal学习07 控制器——接收数据之getBean()和getModel()
  • 二百三十九、Hive——Hive函数全篇
  • 视频去水印电脑版,视频去水印软件
  • 北邮21硕后端开发笔记
  • 【Linux】系统优化:一键切换软件源与安装Docker
  • 【集装箱调度】基于粒子群算法实现考虑重量限制和时间约束的集装箱码头满载AGV自动化调度附matlab代码
  • 使用 ESP32 和 PlatformIO (arduino框架)实现 Over-the-Air(OTA)固件更新
  • 学习笔记——路由网络基础——汇总静态路由
  • 这10个python库,下载都超过5亿
  • Vue3【十一】08使用toRefs和toRef
  • 离散数学---树
  • 【栈】1106. 解析布尔表达式
  • u盘内容无故消失了是什么原因?u盘部分内容无故消失了怎么恢复
  • glm-4v-9b 部署
  • Ansible——unarchive模块
  • Ansible——get_url模块
  • macbook本地部署 pyhive环境连接 hive用例
  • 物理安全防护如何创新强化信息安全体系?
  • 【JAVASE】日期与时间类(上)
  • 如果需要精确的答案,请避免使用float和double
  • 大模型,也在卷价格
  • 开关电源中电感设计
  • 机器视觉——硬件常用基础知识
  • 宝塔 php7.4 安装SQLserver扩展
  • C++中的常见I/O方式
  • Java Web学习笔记23——Vue项目简介
  • [UE 虚幻引擎] DTLoadFbx 运行时加载FBX本地模型插件说明
  • mysql log_bin
  • 数据整理操作及众所周知【数据分析】