vue3子传父——v-model辅助值传递


title: 子组件向父组件传值

date: 2025-04-27 19:11:09
tags: vue3

vue3子传父------v-model辅助值传递

一、子组件发出

1.步骤一创建emit对象

这个对象使用的是defineEmits进行的创建,emit的中文意思又叫发出,你就把他当成一个发出数据的函数方法来用。

js 复制代码
const emit = defineEmits(['update:要传递的对象1','update:要传递的对象2']);
const emit = defineEmits(['update:selectSummary']);

**注意:**要写'update:'的原因是这是vue3的一种约定方式,你可以不这么写,但是一旦父组件调用你的方式涉及到了v-model,这种情况下你必须写'update:'这种形式,要不然父组件找不到你传出来的数据。

2.子组件使用emit对象

一般来说会写一个监听函数或者计算函数,来监听想向外传递的数据,以达到子组件的数据一改变就传递的目的。但方式多样看自己的需求写相关的函数,适当时机触发就可以。

js 复制代码
// 监听选择的对象数组,滤出想要的数据
watch(selection, () => {
    let arr = selection.value.map((item) => { //处理数据
      return item.content;
    });
    emit('update:selectSummary', arr);//发出处理好的数据
  });

二、父组件接受

使用v-model接收对象。在父组件中使用v-model来进行对象的接收。这是一种约定

v-model:名字='父组件对象'

emit('update:名字',子组件对象)

js 复制代码
<chird v-model:selectSummary="selectSummary" /> // 可以写一样的名字
<chird v-model:selectSummary="summary" /> // 也可以写不一样的名字

注意:

v-model实际上只是一种双向绑定简写方法

js 复制代码
<ChildComponent v-model:selectSummary="summary" />

实际写法

js 复制代码
<ChildComponent 
  :selectSummary="summary" // summary将值传递给子组件的selectSummary对应的对象
  @update:selectSummary="(newValue) => summary = newValue"  //更新函数,值给summary
/>
相关推荐
shadowcz0072 分钟前
Live Search API :给大模型装了一个“实时搜索引擎”的插件
linux·服务器·前端·数据库·搜索引擎
一个小白55528 分钟前
nginx 的反向代理 负载均衡 动静分离 重写
linux·运维·前端·nginx·centos·firefox
panrunjun42 分钟前
vue element-plus 集成多语言
前端·javascript·vue.js
蓝莓味的口香糖1 小时前
Vue常用自定义指令-积累的魅力【VUE】
前端·javascript·vue.js
未来之窗软件服务1 小时前
在 Excel 使用macro 常用函数 使用行数 招标专家系统————仙盟创梦IDE
前端·excel·vbs·excel插件·仙盟创梦ide
全马必破三2 小时前
前端性能优化方案
开发语言·前端·javascript
心海资源2 小时前
【心海资源】黄金首饰价格查询单页源码
前端·学习·开源软件
打小就很皮...2 小时前
《从虚拟 DOM 到 Diff 算法:深度解析前端高效更新的核心原理》-简版
前端·javascript·html
神仙别闹2 小时前
基于Java(SSM)+MySQL实现(Web)具有智能推荐功能的图书销售系统
java·前端·mysql
是席木木啊2 小时前
Tomcat:部署前后端分离项目踩坑
前端·javascript·vue.js