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 更严谨、更工程化 的地方。

相关推荐
禅思院1 小时前
前端部署“三层漏斗”完全指南:从CI/CD到自动回滚的工程化实战【开题】
前端·架构·前端框架
快乐肚皮1 小时前
深入理解Loop Engineering
前端·后端
半个落月1 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
风骏时光牛马2 小时前
VHDL十大经典基础功能设计实例代码合集
前端
小兔崽子去哪了2 小时前
Vue3 + Pinia 集成 IGV.js 实现 BAM 文件在线浏览
javascript·vue.js·后端
hunterandroid2 小时前
Notification 通知:从基础到渠道适配
前端
孟陬2 小时前
Claude Code 巧思 `Ctrl+S` 暂存键
前端·后端
PedroQue992 小时前
V1.6.1性能优化:高频路径提速与代码精简
前端·uni-app
猩猩程序员2 小时前
将 LiteLLM 迁移到 Rust —— 构建最快、最轻量的 AI Gateway
前端
小月土星2 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试