当前位置: 首页 > news >正文

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"的语法糖。
http://www.jsqmd.com/news/90314/

相关文章:

  • 48、不确定性量化中的多项式混沌展开与实验设计
  • 49、不确定性量化中的实验设计抽样方法
  • 50、不确定性量化实验设计:采样策略与桁架结构分析
  • 信息学奥赛一本通 1635:【例 5】Strange Way to Express Integers
  • 51、张拉膜结构的不确定性量化设计
  • 52、物理系统不确定性量化与结构随机响应分析
  • 53、结构工程中不确定性的正向传播
  • 54、可靠性分析与概率神经网络的综合解析
  • 突破数学推理三重困境:上海AI Lab提出OREAL强化学习新范式,无需蒸馏超大模型实现性能超越
  • 强力指南:5分钟掌握.brd电路板文件查看的完整解决方案
  • 55、实验设计与结构随机响应分析:从采样方法到实际应用
  • 56、结构随机响应分析方法与广义多项式混沌方法详解
  • 57、随机响应分析与结构建模相关知识解析
  • 字节跳动BFS-Prover-V2模型震撼发布:95.08%准确率改写AI数学推理历史,引领定理证明实用化浪潮
  • 58、结构随机响应分析与 gPC 方法应用
  • BlenderGIS地形生成终极指南:从零到专业级3D场景
  • 59、结构随机响应分析:固定基础与隔震结构对比研究
  • 60、随机优化:随机扩散搜索算法解析
  • Windows 7终极兼容指南:让Umi-OCR免费OCR软件完美运行
  • 61、随机优化、多目标跟踪与神经网络建模技术解析
  • 62、单桩荷载 - 沉降响应的反向传播神经网络建模
  • 百度网盘加速工具BaiduPCS-Web:突破限速的技术实现与实战指南
  • 掌握网络调试:这款免费工具如何让你的开发效率翻倍?
  • 开源突破!Step1X-Edit v1.2重构AI图像编辑逻辑,语义级创作效率提升40%
  • 暗黑3终极智能自动化工具完整配置指南
  • 腾讯HunyuanPortrait横空出世:AI人像动画生成技术迎来革命性突破
  • 通义团队Qwen2.5-VL-32B-Instruct模型发布:多模态AI视觉代理能力再突破
  • Nugget命令行工具:极简文件下载的终极解决方案
  • WebLaTeX:免费高效的LaTeX编辑器终极使用指南
  • Java Excel处理新境界:FastExcel如何让性能与开发体验双丰收