vue3.0父子组件传值
时间: 2023-09-18 21:04:39 浏览: 87
在Vue 3.0中,父子组件之间的传值可以使用props和emit实现。props是父组件向子组件传递数据的一种方式,子组件通过声明props来接收父组件传递的值。父组件可以将数据通过属性的形式绑定到子组件上,子组件可以在props属性中声明接收该属性的类型和默认值。例如:
父组件代码:
<template>
<div>
<child-component :message="parentMessage"></child-component>
</div>
</template>
<script>
import ChildComponent from "./ChildComponent.vue";
export default {
components: {
ChildComponent,
},
data() {
return {
parentMessage: "Hello from parent",
};
},
};
</script>
子组件代码:
<template>
<div>
<p>{{ message }}</p>
</div>
</template>
<script>
export default {
props: {
message: {
type: String,
default: "",
},
},
};
</script>
在这个例子中,父组件传递了一个名为parentMessage的数据到子组件中,子组件使用props接收到父组件传递的message,并在模板中显示出来。
除了props,Vue 3.0还引入了新的API emit,它可以用于在子组件中向父组件发送消息。子组件可以通过$emit方法发送一个自定义事件,并可以传递需要发送的数据。父组件可以通过在子组件上监听该事件,并在回调中接收子组件发送的数据。例如:
子组件代码:
<template>
<div>
<button @click="sendMessage">Send Message</button>
</div>
</template>
<script>
export default {
methods: {
sendMessage() {
this.$emit("messageSent", "Hello from child");
},
},
};
</script>
父组件代码:
<template>
<div>
<child-component @messageSent="handleMessage"></child-component>
</div>
</template>
<script>
import ChildComponent from "./ChildComponent.vue";
export default {
components: {
ChildComponent,
},
methods: {
handleMessage(message) {
console.log(message);
},
},
};
</script>
在这个例子中,子组件中的按钮点击事件调用sendMessage方法,该方法使用$emit发送一个名为messageSent的自定义事件,并将"Hello from child"作为参数传递。父组件在模板中使用@messageSent监听该事件,并通过handleMessage方法处理接收到的消息。在handleMessage方法中,我们打印出了从子组件发送的消息。
阅读全文