Vue 3编写的父子组件示例,包括传递数据和调用父组件方法

下面是一个使用Vue 3编写的父子组件示例,包括传递数据和调用父组件方法:

ChildComponent.vue:

html 复制代码
<template>
  <div>
    <p>Child Component</p>
    <p>Message: {{ message }}</p>
    <button @click="updateMessage">Update Message</button>
  </div>
</template>

<script>
import { defineEmits, defineProps } from 'vue';

export default {
  props: {
    initialMessage: {
      type: String,
      required: true
    }
  },
  emits: ['update:message'],
  setup(props, { emit }) {
    const message = defineProps({
      message: props.initialMessage
    });

    function updateMessage() {
      message.message = 'Hello Vue 3';
      emit('update:message', message.message);
    }

    return {
      message,
      updateMessage
    };
  }
}
</script>

在上面的代码中,我们定义了一个名为ChildComponent的子组件,并声明了一个名为initialMessage的props属性,它的类型为字符串,并且是必需的。我们还定义了一个名为update:message的自定义事件,用于将更新后的消息传递回父组件。

setup()函数中,我们使用defineProps()函数来创建一个响应式的message对象,并将其初始值设置为props.initialMessage。然后,我们定义了一个名为updateMessage()的方法,在点击按钮时将message.message更新为'Hello Vue 3',并通过调用emit()函数来触发update:message事件并将更新后的消息传递给父组件。

ParentComponent.vue:

html 复制代码
<template>
  <div>
    <p>Parent Component</p>
    <child-component :initial-message="message" @update:message="onUpdateMessage"></child-component>
    <p>Updated Message: {{ updatedMessage }}</p>
  </div>
</template>

<script>
import ChildComponent from './ChildComponent.vue';
import { ref } from 'vue';

export default {
  components: {
    ChildComponent
  },
  setup() {
    const message = ref('Hello World');
    const updatedMessage = ref('');

    function onUpdateMessage(value) {
      updatedMessage.value = value;
    }

    return {
      message,
      updatedMessage,
      onUpdateMessage
    };
  }
}
</script>

在上面的代码中,我们定义了一个名为ParentComponent的父组件,并在模板中使用了<child-component>标签来引入子组件。我们将message属性绑定到子组件的initial-message属性上,并监听子组件触发的update:message事件来获取更新后的消息。

setup()函数中,我们使用ref()函数创建了两个响应式变量:messageupdatedMessage。我们还定义了一个名为onUpdateMessage()的方法,在子组件触发update:message事件时被调用,用于将更新后的消息保存到updatedMessage变量中。

这就是一个完整的父子组件示例,包括传递数据和调用父组件方法。

相关推荐
酒鼎14 分钟前
学习笔记(12-02)事件循环 - 实战案例 —⭐
前端·javascript
Bigger19 分钟前
第一章:我是如何剖析 Claude Code 整体架构与启动流程的
前端·aigc·claude
小恰学逆向25 分钟前
【爬虫JS逆向之旅】某球网参数“md5__1038”逆向
javascript·爬虫
竹林81826 分钟前
从“连接失败”到丝滑登录:我用 ethers.js v6 搞定 MetaMask 钱包连接的全过程
前端·javascript
oi..29 分钟前
《Web 安全入门|XSS 漏洞原理、CSP 策略与 HttpOnly 防护实践》
前端·网络·测试工具·安全·web安全·xss
UXbot39 分钟前
2026年AI全链路产品开发工具对比:5款从创意到上线一站式平台深度解析
前端·ui·kotlin·软件构建·swift·原型模式
一拳不是超人1 小时前
前端工程师也要懂的服务器部署知识:从 Nginx 到 CI/CD
服务器·前端
AlkaidSTART1 小时前
TanStack Query 技术指南:异步状态管理核心实践
前端·react.js
三原1 小时前
超级好用的三原后台管理v1.0.0发布🎉(Vue3 + Ant Design Vue + Java Spring Boot )附源码
java·vue.js·开源
前端那点事1 小时前
前端必看!JS高频实用案例(单行代码+实战场景+十大排序)
javascript