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>,是组件通信的补充方案
相关推荐
吴声子夜歌1 小时前
ES6——二进制数组详解
前端·ecmascript·es6
码事漫谈1 小时前
手把手带你部署本地模型,让你Token自由(小白专属)
前端·后端
ZC跨境爬虫1 小时前
【爬虫实战对比】Requests vs Scrapy 笔趣阁小说爬虫,从单线程到高效并发的全方位升级
前端·爬虫·scrapy·html
爱上好庆祝1 小时前
svg图片
前端·css·学习·html·css3
橘子编程2 小时前
JavaScript与TypeScript终极指南
javascript·ubuntu·typescript
王夏奇2 小时前
python中的__all__ 具体用法
java·前端·python
叫我一声阿雷吧2 小时前
JS 入门通关手册(45):浏览器渲染原理与重绘重排(性能优化核心,面试必考
javascript·前端面试·前端性能优化·浏览器渲染·浏览器渲染原理,重排重绘·reflow·repaint
大家的林语冰2 小时前
《前端周刊》尤大开源 Vite+ 全家桶,前端工业革命启动;尤大爆料 Void 云服务新产品,Vite 进军全栈开发;ECMA 源码映射规范......
前端·javascript·vue.js
jiayong233 小时前
第 8 课:开始引入组合式函数
前端·javascript·学习
田八3 小时前
聊聊AI的发展史,AI的爆发并不是偶然
前端·人工智能·程序员