vue子组件给父组件传值及父组件给子组件传值

本文详细介绍了Vue.js中子组件向父组件以及父组件向子组件传递数据的方法。子组件使用this.$emit()发送数据给父组件,而父组件通过props属性将数据传递给子组件。

引自:https://blog.youkuaiyun.com/weixin_38888773/article/details/81902789

子组件给父组件传值

子组件:


<template>
    <div class="app">
       <input @click="sendMsg" type="button" value="给父组件传递值">
    </div>
</template>
<script>
export default {
 
    data () {
        return {
            //将msg传递给父组件
            msg: "我是子组件的msg",
        }
    },
     methods:{
         sendMsg(){
             //func: 是父组件指定的传数据绑定的函数,this.msg:子组件给父组件传递的数据
             this.$emit('func',this.msg)
         }
     }
}
</script>

子组件通过this.$emit()的方式将值传递给父组件

注意:这里的func是父组件中绑定的函数名

父组件:

<template>
    <div class="app">
        <child @func="getMsgFormSon"></child>
    </div>
</template>
<script>
import child from './child.vue'
export default {
    data () {
        return {
            msgFormSon: "this is msg"
        }
    },
    components:{
        child,
    },
    methods:{
            getMsgFormSon(data){
                this.msgFormSon = data
                console.log(this.msgFormSon)
            }
    }
}
</script>

父组件给子组件传值

父组件:

<template>
    <parent>
        <child :list="list"></child> //在这里绑定list对象
    </parent>
</template>
import child from 'child.vue';
export default{
  components:{child},
  data(){
   return {
   //父组件的数据绑定到子组件的包裹层上 
  list:["haha","hehe","xixi"];
 }
}

子组件:

<template>
   <ul>
        <li v-for="(item ,index)in list">{{item}}</li>
    </ul>
</template>
export default{
     props:{
    list:{
      type:Array,//type为Array,default为函数
      default(){
        return [
          "hahaxixihehe"//默认初始值
        ]}}
    },//用props属性进行传数据,此时子组件已经获取到list的数据了
       data(){
         return {}  
    }   
} 

 

Vue3 子组件父组件动态主要有以下实现方式: ### 利用自定义事件(`emits`) 在 Vue3 里,父子组件间存在一个桥梁即 `emits` 触发事件,子组件注册该事件,父组件监听此事件,一旦触发便执行相应函数,进而改变前端界面展示的数据 [^3]。 以下是示例代码: #### 子组件 ```vue <template> <button @click="sendData">发送数据给父组件</button> </template> <script lang="ts" setup> import { defineEmits } from 'vue'; // 定义要触发的事件 const emits = defineEmits(['add']); // 子组件中触发事件并递数据 const sendData = () => { const dynamicData = { message: '这是动态数据', timestamp: new Date().toISOString() }; emits('add', dynamicData); }; </script> ``` #### 父组件 ```vue <template> <div> <ChildComponent @add="handleAdd" /> <p>接收到的数据: {{ receivedData }}</p> </div> </template> <script lang="ts" setup> import { ref } from 'vue'; import ChildComponent from './ChildComponent.vue'; // 用于存储接收到的数据 const receivedData = ref({}); // 处理子组件递过来的数据 const handleAdd = (data) => { receivedData.value = data; console.log('接收到子组件的数据:', data); }; </script> ``` ### 借助 `defineProps` 和 `defineEmits` 结合 子组件可以通过 `defineProps` 接收父组件递的方法,然后调用该方法将动态数据递给父组件。 #### 子组件 ```vue <template> <button @click="sendValueToParent">发送父组件</button> </template> <script lang="ts" setup> import { defineProps } from 'vue'; // 定义接收的父组件方法 const props = defineProps({ parentMethod: { type: Function, required: true } }); // 调用父组件方法并递动态数据 const sendValueToParent = () => { const dynamicValue = { info: '动态信息', count: Math.floor(Math.random() * 100) }; props.parentMethod(dynamicValue); }; </script> ``` #### 父组件 ```vue <template> <div> <ChildComponent :parentMethod="childValueHandlingMethod" /> <p>子组件递的: {{ subRequests }}</p> </div> </template> <script lang="ts" setup> import { ref } from 'vue'; import ChildComponent from './ChildComponent.vue'; // 用于存储子组件递的 const subRequests = ref([]); // 处理子组件递过来的 const childValueHandlingMethod = (request) => { console.log('从子组件来的:', request); subRequests.value.push(request); }; </script> ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值