总结一下vue3的组件之间数据转递,子组件传父组件,父组件传子组件

文章目录

父传子

1.子组件定义属性

html 复制代码
<!-- 子组件代码 -->
<template> 
<h1>子组件</h1> 
    <div>这是一个子组件</div>
    <div>标题:{{ title }}</div>
    <div>名称:{{ name }}</div>
    <div>年龄:{{ age }}</div>
</template> 
<script lang="ts" setup>
import { defineProps,ref} from 'vue';
//定义属性,
const attribute = defineProps({
    title:{
        // title属性string类型
        type:String,
        required: true//必填
    },
    name:{
        type:String,
        required:true
    },
    age:{
        type:Number,
        required:true
    }
});
const title=ref("");
const name=ref("");
const age=ref(0);
title.value=attribute.title
name.value=attribute.name
age.value=attribute.age
</script>
html 复制代码
<!-- 父组件代码 -->
<template>
    <h1>父组件</h1>
    <hr> 
    <!-- 给组件属性传参 -->
    <son :title="sonTitle" :name="sonName" :age="sonAge"   ></son>
</template>
<script lang="ts" setup>
import { ref } from 'vue';
import son from './Son.vue'; 
const sonTitle=ref("子标题");
const sonName = ref("子名称");
const sonAge = ref("子年龄");
</script>
  • 效果:

子传父

  1. 现在子组件定义函数
html 复制代码
<!-- 子组件代码 -->
<template> 
    <h1>子组件</h1> 
        <div>这是一个子组件</div>
        <div>标题:<el-input v-model="title" /></div>
        <div>名称:<el-input v-model="name" /></div>
        <div>年龄:<el-input v-model="age" /></div>
        <button @click="f_SonSendParent">发送给父组件</button>
</template> 
<script lang="ts" setup>
    import { defineEmits,ref} from 'vue';  
    const ParentEvent = defineEmits(["EventName"])//定义组件自己的函数,
    const title=ref("");
    const name=ref("");
    const age=ref(0);
    const f_SonSendParent=()=>{
        ParentEvent("EventName",title.value,name.value,age.value);
    }
</script> 
  1. 父组件给子组件定义的函数传入函数
html 复制代码
<!-- 父组件代码 -->
<template>
    <h1>父组件</h1>
    <hr> 
    接收的参数:<br>
    标题:{{ sonTitle }}<br>
    名称: {{ sonName }}<br>
    年龄:{{ sonAge }}<br>
    <!-- 给组件属性传参 -->
    <son :title="sonTitle" :name="sonName" :age="12"  @EventName="f_a"  ></son>
</template>
<script lang="ts" setup>
import { ref } from 'vue';
import son from './Son.vue'; 
const sonTitle=ref("子标题");
const sonName = ref("子名称");
const sonAge = ref(2);
const f_a=(a:string,b:string,c:number)=>{
    sonTitle.value=a;
    sonName.value=b;
    sonAge.value=c;
}
</script>
  • 效果
相关推荐
孟祥_成都6 分钟前
深入 Nestjs 底层概念(1):依赖注入和面向切面编程 AOP
前端·node.js·nestjs
let_code7 分钟前
CopilotKit-丝滑连接agent和应用-理论篇
前端·agent·ai编程
Apifox32 分钟前
Apifox 11 月更新|AI 生成测试用例能力持续升级、JSON Body 自动补全、支持为响应组件添加描述和 Header
前端·后端·测试
木易士心32 分钟前
深入剖析:按下 F5 后,浏览器前端究竟发生了什么?
前端·javascript
在掘金8011034 分钟前
vue3中使用medium-zoom
前端·vue.js
xump1 小时前
如何在DevTools选中调试一个实时交互才能显示的元素样式
前端·javascript·css
折翅嘀皇虫1 小时前
fastdds.type_propagation 详解
java·服务器·前端
Front_Yue1 小时前
深入探究跨域请求及其解决方案
前端·javascript
wordbaby1 小时前
React Native 进阶实战:基于 Server-Driven UI 的动态表单架构设计
前端·react native·react.js
抱琴_1 小时前
【Vue3】我用 Vue 封装了个 ECharts Hooks,同事看了直接拿去复用
前端·vue.js