Vue3 中的 defineExpose 完全指南

文章目录

defineExposeVue3 组合式 API <script setup> 中的专用编译宏,核心作用 :在 <script setup> 语法糖下,主动暴露组件的属性和方法 ,让父组件可以通过 ref / $parent 访问子组件的成员。

关键背景(必看)

在普通的 Vue3 选项式 API 中,组件的属性和方法默认会暴露给父组件;

但在 <script setup> 语法糖下,组件默认是封闭的 ,所有变量、方法都不会自动暴露,父组件无法直接访问。

这就是 defineExpose 存在的意义。


一、基础用法

1. 子组件(暴露内容)

vue 复制代码
<!-- Child.vue -->
<script setup>
import { ref } from 'vue'

// 子组件内部数据
const count = ref(0)
// 子组件内部方法
const addCount = () => {
  count.value++
}

// 核心:使用 defineExpose 暴露属性/方法
defineExpose({
  count,
  addCount
})
</script>

<template>
  <div>子组件计数:{{ count }}</div>
</template>

2. 父组件(访问子组件)

通过 ref 获取子组件实例,调用暴露的方法/访问属性:

vue 复制代码
<!-- Parent.vue -->
<script setup>
import { ref } from 'vue'
import Child from './Child.vue'

// 获取子组件 DOM 实例
const childRef = ref(null)

// 调用子组件暴露的方法
const triggerChild = () => {
  // 访问子组件数据
  console.log('子组件count:', childRef.value.count)
  // 调用子组件方法
  childRef.value.addCount()
}
</script>

<template>
  <Child ref="childRef" />
  <button @click="triggerChild">调用子组件方法</button>
</template>

二、核心特性

  1. 无需导入defineExpose 是编译宏,直接使用,不需要从 vue 中导入
  2. 精准暴露:只暴露你写在对象里的成员,未暴露的内容完全私有
  3. TS 支持:可以配合类型注解,提供类型提示
  4. 仅适用于 <script setup>:普通选项式 API 不需要它

三、TypeScript 写法

vue 复制代码
<script setup lang="ts">
import { ref } from 'vue'

const count = ref<number>(0)
const addCount = () => count.value++

// 带类型的暴露
defineExpose<{
  count: number
  addCount: () => void
}>()
</script>

四、常见使用场景

  1. 父组件主动调用子组件的方法(如表单重置、弹窗关闭、列表刷新)
  2. 父组件获取子组件的响应式数据
  3. 封装公共组件时,提供对外调用的 API

五、注意事项

  1. 不要过度暴露:只暴露必要的成员,保持组件封装性
  2. 挂载后才能访问 :父组件必须在组件挂载完成后 (如 onMounted)才能访问子组件实例
  3. 与 defineProps / defineEmits 区分
    • defineProps:父 → 子 传值
    • defineEmits:子 → 父 触发事件
    • defineExpose:父 → 子 主动调用成员

六、总结

  1. <script setup> 组件默认封闭,必须用 defineExpose 暴露成员
  2. 语法:defineExpose({ 变量, 方法 })
  3. 父组件通过 ref 获取子组件实例,访问暴露的内容
  4. 仅用于组合式 API <script setup>,是组件通信的补充方案
相关推荐
Csvn6 小时前
OpenSpec 详细使用教程
前端
之歆7 小时前
Day19_LESS 完全指南——从入门到工程实践
前端·css·less
云水一下8 小时前
HTML5 从入门到精通:实战收官——从零搭建完整静态网站,综合运用所有知识
前端·html5
不总是8 小时前
Windows 系统 Node.js 免安装版(zip)安装与配置教程(2026 最新)
前端·windows·node.js
冬奇Lab8 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
zhangyao9403309 小时前
开发pc端时,表格的高度怎么设置才能铺满页面
前端·javascript·elementui
XinZong9 小时前
实测OpenClaw虾淘:全民工具AI时代,冷门非工具类的Skill还能出圈吗?
javascript
kjs--9 小时前
浏览器书签执行脚本
前端
烛衔溟9 小时前
TypeScript 类的类型 —— 作为类型使用
javascript·ubuntu·typescript
之歆10 小时前
Day16_JavaScript 轮播图与事件工程实战(下篇)
服务器·开发语言·前端·javascript·网络·性能优化