news 2026/5/1 6:51:44

Vue的组件通信方式

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue的组件通信方式

一. props 父=》子 ;emit 子=》父 通信

//父组件 <template> <div class="demo"> <Child :text="text" @changeText="changeText" />//子组件触发change-text事件,更新text的值 <h1>{{ appText }}</h1>//点击子组件按钮后为hello worldchanged </div> </template> <script lang="ts" setup> import Child from '@/views/childOne .vue' import { ref } from 'vue' const text = ref('hello world') const appText = ref('hello world') // 父组件监听子组件触发的change-text事件,更新text的值 const changeText = (newText: string) => { appText.value += newText } </script> <style scoped></style> //子组件 <template> <div> <h2>{{ props.text }}</h2> <button @click="changeText">change</button> </div> </template> <script lang="ts" setup> // 子组件接收父组件传递的text属性 const props = defineProps({ text: String }); const emit = defineEmits(['changeText']) // 子组件点击按钮触发changeText事件,传递新的文本 const changeText = () => { emit('changeText', ' changed')//子组件触发changeText事件,传递新的文本 } </script> <style scoped></style>

二.expose +ref 导出获取子组件的属性和方法

<template> <div>父组件:拿到子组件的message数据:{{ msg }}</div> <button @click="callChildFn">调用子组件的方法</button> <hr /> <Child ref="com" />//ref绑定子组件 </template> <script setup> import Child from './child.vue'; const com = ref(null); // 通过 模板ref 绑定子组件 const msg = ref(''); onMounted(() => { // 在加载完成后,将子组件的 message 赋值给 msg msg.value = com.value.message; }); function callChildFn() { // 调用子组件的 show方法 com.value.show(); // 重新将 子组件的message 赋值给 msg msg.value = com.value.message; } </script> //子组件 <template> <div> Expose子组件</div> </template> <script setup> const message = ref('子组件传递得信息'); const show = () => { console.log('子组件得方法'); }; //交出子组件函数 defineExpose({ message, show, }); </script>

三.v-model 双向通信

<template> <div> <Child v-model="text" v-model:msg1="message1" v-model:msg2="message2"/> </div> </template> <script setup lang="ts"> import Child from '@/views/childOne .vue'; import { ref } from 'vue'; const text = ref<string>('默认'); const message1 = ref<string>('水果1'); const message2 = ref<string>('水果2'); </script>
//子组件: <template> <div> <div><button @click="changeText">修改text</button> {{ modelValue }}</div> <div><button @click="changeMsg1">修改msg1</button> {{ msg1 }}</div> <div><button @click="changeMsg2">修改msg2</button> {{ msg2 }}</div> </div> </template> <script setup lang="ts"> // 接收 defineProps({ 'modelValue': String, //默认为modelValue msg1: String, msg2: String, }); //默认为modelValue,update:+方法名 const emit = defineEmits(['update:modelValue', 'update:msg1', 'update:msg2']); function changeMsg1() { emit('update:msg1', '蔬菜1'); } function changeMsg2() { emit('update:msg2', '蔬菜2'); } function changeText() { emit('update:modelValue', 'Text2') } </script>

总结:

  1. Props(单向数据流)

    • 细节:父组件通过v-bind(或:) 将数据绑定到子组件的属性上。子组件需要在props选项中声明接收的属性名,并可指定类型 (type)、是否必需 (required)、默认值 (default)、验证函数 (validator)。
  2. Emit (自定义事件)

    • 细节:子组件const emit = defineEmits(['event-name']); emit('event-name', payload)(Composition API +<script setup>) 触发自定义事件。payload是传递给父组件的数据。
    • 父组件处理:父组件在模板中使用v-on(或@) 监听子组件触发的事件,如@event-name="handler"handler是父组件中定义的方法,接收payload作为参数进行处理。
  3. Expose + Ref

    • 细节 (Vue 3):子组件使用defineExpose显式暴露其内部属性或方法(如defineExpose({ publicMethod }))。
    • 父组件操作:父组件通过ref属性 (<ChildComponent ref="childRef" />) 为子组件实例创建引用。在父组件脚本中,const childRef = ref(null); childRef.value?.publicMethod()(Composition API) 访问暴露的内容。
    • 注意:访问需确保子组件已挂载(如在mounted钩子或watchref变化后)。
  4. v-model (双向绑定语法糖)

    • 细节 (Vue 3):v-model默认对应一个名为modelValueprop和一个名为update:modelValue的事件。父组件v-model="parentData",子组件接收modelValueprop,并在需要更新时触发emit('update:modelValue', newValue)
    • 参数:可指定参数实现多个绑定,如v-model:title="pageTitle",对应titlepropupdate:title事件。
    • 本质::modelValue="parentData" @update:modelValue="parentData = $event"的语法糖。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/1 2:41:20

51、张拉膜结构的不确定性量化设计

张拉膜结构的不确定性量化设计 1. 张拉膜结构概述 张拉膜结构是一种常见的建筑结构形式,在不确定条件下的设计优化至关重要。这里以一个实际的圆锥张拉膜结构为例进行探讨。该结构的相关细节如下: - 膜纱方向 :经纱沿径向,纬纱沿圆周方向。 - 膜厚度 :1.0 毫米。 …

作者头像 李华
网站建设 2026/4/16 12:34:00

65、随机分析与模型评估相关研究

随机分析与模型评估相关研究 在工程和科学领域,随机分析和模型评估是解决复杂问题的重要手段。本文将深入探讨随机分析的基础知识,以及不同模型在实际应用中的表现和评估方法。 随机分析基础 随机分析在处理具有不确定性的问题时至关重要。以结构动力学为例,当结构受到随…

作者头像 李华
网站建设 2026/4/23 20:52:44

Java Excel处理新境界:FastExcel如何让性能与开发体验双丰收

Java Excel处理新境界&#xff1a;FastExcel如何让性能与开发体验双丰收 【免费下载链接】fastexcel Generate and read big Excel files quickly 项目地址: https://gitcode.com/gh_mirrors/fas/fastexcel 还在为Excel处理时的内存溢出和龟速性能而头疼吗&#xff1f;作…

作者头像 李华
网站建设 2026/4/21 4:34:11

专业GPU显存检测:memtest_vulkan深度应用指南

专业GPU显存检测&#xff1a;memtest_vulkan深度应用指南 【免费下载链接】memtest_vulkan Vulkan compute tool for testing video memory stability 项目地址: https://gitcode.com/gh_mirrors/me/memtest_vulkan 请根据以下要求创作一篇关于memtest_vulkan GPU显存测…

作者头像 李华
网站建设 2026/5/1 1:27:42

如何快速掌握Termius中文版:移动端SSH客户端的完整实战指南

如何快速掌握Termius中文版&#xff1a;移动端SSH客户端的完整实战指南 【免费下载链接】Termius-zh_CN 汉化版的Termius安卓客户端 项目地址: https://gitcode.com/alongw/Termius-zh_CN 还在为移动端SSH客户端的英文界面而烦恼吗&#xff1f;面对满屏的英文菜单和提示…

作者头像 李华
网站建设 2026/4/30 11:08:25

LyricsX终极指南:如何在Mac上打造专业级桌面歌词体验

LyricsX终极指南&#xff1a;如何在Mac上打造专业级桌面歌词体验 【免费下载链接】Lyrics Swift-based iTunes plug-in to display lyrics on the desktop. 项目地址: https://gitcode.com/gh_mirrors/lyr/Lyrics 还在为Mac上找不到合适的歌词显示工具而烦恼吗&#xff…

作者头像 李华