父组件调用子组件的方法

父组件

在父组件中调用子组件的sayHello()函数

javascript 复制代码
<template>
	<div>
		<button @click="getChild('wendu')">触发子组件方法wendu</button>
		<button @click="getChild('shidu')">触发子组件方法shidu</button>
		<el-dialog v-model="dialogVisible" title="title" width="80%" draggable style="background: #091b37 !important; padding:1px !important" :close-on-click-modal="false">
			<transition>
				<keep-alive>
					<component :is="Child" ref="childRef" :key="b"> </component>
				</keep-alive>
			</transition>
		</el-dialog>
	</div>
</template>
<script setup>
import { ref, nextTick } from 'vue'
import Child from './components/wendu.vue'

const b = ref('')
const dialogVisible = ref(false)
// 定义与 ref 同名变量
const childRef = ref(null)
const getChild = (a) => {
  dialogVisible.value = true
  b.value = a
  nextTick(() => {
    if (childRef.value) {
      console.log(childRef.value);
      console.log(childRef.value.sayHello);
      childRef.value.sayHello(a);
    } else {
      console.log("子组件尚未渲染");
    }
  })
}
</script>

子组件

javascript 复制代码
<template>
	<div>我是子组件</div>
	<input type="text" v-model="inputValue">
</template>
 
<script setup>
import { ref, defineExpose } from 'vue'

// 第一步:定义子组件的方法
const sayHello = (value) => {
	console.log(value)
}
// 第二部:暴露方法
defineExpose({
	sayHello 
})
</script>
相关推荐
跳动的梦想家h27 分钟前
环境配置 + AI 提效双管齐下
java·vue.js·spring
夏幻灵1 小时前
HTML5里最常用的十大标签
前端·html·html5
冰暮流星1 小时前
javascript之二重循环练习
开发语言·javascript·数据库
Mr Xu_1 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝1 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions1 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发1 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_1 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞051 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
我爱加班、、1 小时前
Websocket能携带token过去后端吗
前端·后端·websocket