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

相关推荐
码事漫谈5 小时前
大模型输出的“隐性结构塌缩”问题及对策
前端·后端
这儿有一堆花5 小时前
前端三件套真的落后了吗?揭开现代 Web 开发的底层逻辑
前端·javascript·css·html5
.Cnn6 小时前
JavaScript 前端基础笔记(网页交互核心)
前端·javascript·笔记·交互
醉酒的李白、6 小时前
Vue3 组件通信本质:Props 下发,Emits 回传
前端·javascript·vue.js
anOnion6 小时前
构建无障碍组件之Window Splitter Pattern
前端·html·交互设计
小眼哥7 小时前
SpringBoot整合Vue代码生成exe运行程序以及windows安装包
vue.js·windows·spring boot
NotFound4867 小时前
实战分享Python爬虫,如何实现高效解析 Web of Science 文献数据并导出 CSV
前端·爬虫·python
徐小夕7 小时前
PDF无限制预览!Jit-Viewer V1.5.0开源文档预览神器正式发布
前端·vue.js·github
WangJunXiang67 小时前
Haproxy搭建Web群集
前端
吴声子夜歌7 小时前
Vue.js——自定义指令
前端·vue.js·flutter