在Vue中,子组件向父组件传递数据通常通过两种方式实现:事件和回调函数。这两种方式允许子组件与其父组件进行通信,传递数据或触发特定的行为。
1. 通过事件传递数据
子组件可以通过触发自定义事件,并将数据作为事件的参数来向父组件传递数据。
子组件:
<template>
<div>
<h2>子组件</h2>
<input v-model="num"><br>
<!-- 定义点击事件,触发向父组件传递数据的函数-->
<button @click="sendPa">传递</button>
</div>
</template>
<script>
export default {
name: "Demo4",
data(){
return{
num:null
}
},
methods:{
// 向父组件传递数据函数
sendPa(){
console.log("1112")
// @paFun 为 定义的父组件事件,这里我理解的为将事件作为数据的载体,传递给父组件
this.$emit('paFun',this.num)
}
}
}
</script>
<style scoped>
</style>
父组件:
<template>
<div>
<h1>父组件</h1>
<p>{{num}}</p>
<!-- 插入子组件-->
<!-- 注意:这里调用父组件的函数不需要传参-->
<Demo4 @paFun=addFun></Demo4>
</div>
</template>
<script>
import Demo4 from "@/components/Demo4";
export default {
name: "Demo5Pa",
components:{
Demo4
},
data(){
return{
num:0
}
},
methods:{
addFun(num){
this.num=num
}
}
}
</script>
<style scoped>
</style>
效果:
2. 通过回调函数传递数据
另一种常见的方式是通过在子组件中定义回调函数,并将父组件的方法传递给子组件,以便子组件可以直接调用父组件的方法并传递数据。
子组件:
<template>
<button @click="sendDataToParent">传递数据给父组件</button>
</template>
<script>
export default {
methods: {
sendDataToParent() {
// 调用父组件传递过来的方法,并传递数据 payload
this.$props.onSendData({ message: 'Hello from child!' });
}
},
props: {
onSendData: {
type: Function,
required: true
}
}
};
</script>
父组件:
<template>
<div>
<p>从子组件接收到的消息:{{ messageFromChild }}</p>
<!-- 将父组件中的方法通过 props 传递给子组件 -->
<child-component :on-send-data="handleDataFromChild"></child-component>
</div>
</template>
<script>
import ChildComponent from './ChildComponent.vue';
export default {
components: {
ChildComponent
},
data() {
return {
messageFromChild: ''
};
},
methods: {
handleDataFromChild(data) {
// 处理来自子组件的数据
this.messageFromChild = data.message;
}
}
};
</script>
在这个例子中,子组件通过 props 接收了一个名为 onSendData 的函数,并且在 sendDataToParent 方法中调用了这个函数,将数据作为参数传递给父组件。父组件通过 :on-send-data 将自己的 handleDataFromChild 方法传递给子组件,从而实现了子组件向父组件传递数据的功能。
这两种方式各有其适用的场景,选择合适的方式取决于具体的需求和组件之间的关系。通常来说,事件更适合于子组件通知父组件发生了某些事情,而回调函数更适合于父组件将处理逻辑传递给子组件。
最后
如果感觉有收获的话,点个赞
标签:Vue,函数,传递数据,num,组件,data,methods From: https://blog.csdn.net/m0_73940426/article/details/140362024