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>,是组件通信的补充方案
相关推荐
泯泷2 小时前
阶段一:从 0 看懂 JSVMP 架构,先在脑子里搭出一台最小 JSVM
前端·javascript·架构
mengchanmian2 小时前
前端node常用配置
前端
华洛3 小时前
利好打工人,openclaw不是企业提效工具,而是个人助理
前端·javascript·产品经理
xkxnq3 小时前
第六阶段:Vue生态高级整合与优化(第93天)Element Plus进阶:自定义主题(变量覆盖)+ 全局配置与组件按需加载优化
前端·javascript·vue.js
A黄俊辉A4 小时前
vue css中 :global的使用
前端·javascript·vue.js
小码哥_常4 小时前
被EdgeToEdge适配折磨疯了,谁懂!
前端
小码哥_常4 小时前
从Groovy到KTS:Android Gradle脚本的华丽转身
前端
灵感__idea4 小时前
Hello 算法:复杂问题的应对策略
前端·javascript·算法
chushiyunen5 小时前
python中的内置属性 todo
开发语言·javascript·python