vue3的组件间通信ref子组件需要把父组件要的ref数据开放

文章目录

vue3子组件需要把父组件要的ref数据开放

Vue3 比 Vue2 更"封闭、更安全",默认不对外暴露任何东西!

1. 先回忆 Vue2

Vue2 不管是 data 、 methods 、 computed ......

只要你写在组件里,父组件通过 $refs 全都能拿到!

javascript 复制代码
js
  
// Vue2
data() {
  return { money: 100 }
},
methods: {
  fn() {}
}

// 父组件直接用
this.$refs.children1.money = 200
this.$refs.children1.fn()
 

Vue2 的问题:

  • 不安全 → 父组件随便改子组件内部数据
  • 不规范 → 子组件管不住自己的东西

2. Vue3 彻底改了

javascript 复制代码
在  <script setup>  里:
内部变量、函数,默认全部是 私有 的!
 
js
  
// 子组件
let money = ref(9999) // 默认是私有的
function fn() {}     // 默认也是私有的
 
 
父组件就算拿到实例,也访问不到!
 
js
  
children1.value.money // undefined
children1.value.fn() // 报错
 
 
为什么要这么设计?
 
- 安全:子组件自己决定哪些能给外面用
- 规范:父不能乱改子内部
- 低耦合:组件更独立

3. 所以才需要 defineExpose()

它的作用就是:

我允许外面用的,我才暴露!

javascript 复制代码
js
  
defineExpose({
  money, // 只有这个,父组件才能访问
})

最终对比(最清晰)

  • Vue2:默认全公开 → 不安全
  • Vue3 :默认全封闭 → 安全
    → 想让外面用,必须 手动 defineExpose

Vue2 直接用实例就行,因为默认都暴露

Vue3 更封闭,默认不暴露,所以要 defineExpose

这就是 Vue3 比 Vue2 更严谨、更工程化 的地方。

相关推荐
我是伪码农2 小时前
Vue 2.10
前端·javascript·vue.js
AAA阿giao2 小时前
React 性能优化双子星:深入、全面解析 useMemo 与 useCallback
前端·javascript·react.js
不想秃头的程序员2 小时前
父传子全解析:从基础到实战,新手也能零踩坑
前端·vue.js·面试
大时光2 小时前
gsap 配置解读 --5
前端
Wect2 小时前
LeetCode 25. K个一组翻转链表:两种解法详解+避坑指南
前端·算法·typescript
shadowingszy2 小时前
【前端趋势调查系列】带你看看前端生态圈的技术趋势state-of-js 2025详细解读
前端·javascript·vue.js
@菜菜_达2 小时前
CSS是什么?
前端·css
2301_796512522 小时前
【精通篇】打造React Native鸿蒙跨平台开发高级复合组件库开发系列:Sticky 粘性布局(始终会固定在屏幕顶部)
javascript·react native·react.js·ecmascript·harmonyos
Amumu121382 小时前
CSS基础选择器
前端·css