【java入门到放弃】VUE部分知识点

父子通信

vue2

  1. 父组件通过 props 将数据传递给子组件
  2. 子组件利用 $emit 通知父组件修改更新

单向数据流:父级props 的数据更新,会向下流动,影响子组件。这个数据流动是单向的

vue3

父传子基本思想

  1. 父组件中给子组件绑定属性
  2. 子组件内部通过props选项接收数据

子传父基本思想

  1. 父组件中给子组件标签通过@绑定事件
  2. 子组件内部通过 emit 方法触发事件

模版引用

如果父组件需要"知道这个值变化",

那这个值就不该在子组件。就需要使用父子通信,值在父组件这里。

如果父组件只需要"让你做件事",

那就用模板引用获取。

vue的初始化顺序,先beforeCreate,然后data / methods / computed / watch 初始化,再然后created

所以模板引用需要写在mounted里。

vue2

vue 复制代码
<template>
     <input ref="username" />
     <ChildComp ref="child" />
	 <ChildComp v-if="showChild" ref="child" />
</template>
<script>
    mounted() {
      //1、普通dom元素
      this.$refs.username.focus()
      //2、获取子组件实例(包含:data、methods、props、$el(根 DOM)、$refs(子组件内部 ref)、computed)
      console.log(this.$refs.child)  
    }
    methods: {
      openChild() {
        this.showChild = true
        //3、条件渲染 v-if  列表渲染 v-for 动态组件/弹窗  需要使用this.$nextTick获取
        // ❌ 这里访问 this.$refs.child 可能 undefined
        this.$nextTick(() => {
          this.$refs.child.doSomething() // ✅ 安全
        })
      }
    }
</script>

Vue2 的模板引用非常"强大",几乎可以随意操作子组件的内部实现,这也是 Vue3 收紧的原因。

vue3

子组件实例 默认只暴露对父可见的接口 (需要 defineExpose

vue 复制代码
获取DOM
<template>
  <input ref="username" />
  <button @click="focusInput">聚焦</button>
</template>

<script setup>
import { ref, onMounted } from 'vue'

const username = ref(null)

const focusInput = () => {
  username.value.focus()
}

onMounted(() => {
  console.log(username.value) // ✅ 已挂载的 DOM
})
</script>

获取子组件实例
<template>
  <ChildComp ref="childRef" />
  <button @click="openChild">打开子组件</button>
</template>

<script setup>
import { ref } from 'vue'
import ChildComp from './ChildComp.vue'

const childRef = ref(null)

const openChild = () => {
  childRef.value.open() // 调用子组件暴露的方法
}
</script>
<script setup>
import { defineExpose } from 'vue'

const open = () => {
  console.log('子组件打开了')
}

defineExpose({ open }) // ⚠️ 必须暴露
</script>
相关推荐
两年半的个人练习生^_^5 分钟前
JMM 进阶:彻底理解 volatile 实现原理
java·开发语言
Yeats_Liao8 分钟前
Java网络编程(五):Selector选择器与高并发实现
java·后端·架构
AC赳赳老秦15 分钟前
OpenClaw任务复盘自动化:统计每日完成工作、遗留问题,优化工作节奏
java·大数据·linux·运维·服务器·数据库·openclaw
布兰妮甜16 分钟前
Vue 项目 `localhost:3000` 打不开?404 常见原因排查指南
前端·javascript·vue.js·vuecli·4040排查
森林的尽头是阳光20 分钟前
前端使用postman快速造数据
前端·javascript·vue·postman·造数·本地测试
兰令水22 分钟前
leecodecode【层序遍历】【2026.6.3打卡-java版本】
java·开发语言
Halo_tjn23 分钟前
反射与设计模式2
java·开发语言·算法
YDS82924 分钟前
DeepSeek RAG&MCP + Agent智能体项目 —— 动态决策策略的接口对接
java·spring boot·ai·agent·spring ai·deepseek
zfoo-framework24 分钟前
跨服架构设计模式(同构进程+选主转发)
java
小猿备忘录29 分钟前
Spring Security OAuth2 双Token机制精讲:原理、配置与常见坑点全解析
java·前端·spring·中间件