vue3中子向父传数据

父组件

首先,我们创建一个父组件,名为 ParentComponent.vue

复制代码
<template>
  <div>
    <h1>父组件</h1>
    <p>从子组件接收到的数据:{{ receivedData }}</p>
    <ChildComponent @sendData="updateData" />
  </div>
</template>

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

const receivedData = ref('');

function updateData(data) {
  receivedData.value = data;
}
</script>

<style scoped>
/* 可选的样式部分 */
</style>

代码解释

1,在 <template> 部分,我们展示父组件的数据 receivedData,并通过自定义事件 sendData 来接收子组件传递的数据。

2,在 <script setup> 部分,我们引入了Vue3的 ref 来创建响应式变量 receivedData。

3,updateData 方法用于更新接收到的数据。

4,我们通过引入并使用子组件 ChildComponent,同时监听其 sendData 事件并调用 updateData 方法。

子组件

接下来,我们创建子组件,名为 ChildComponent.vue

复制代码
<template>
  <div>
    <h2>子组件</h2>
    <input v-model="inputData" placeholder="请输入数据">
    <button @click="sendDataToParent">发送数据到父组件</button>
  </div>
</template>

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

const inputData = ref('');

const emit = defineEmits(['sendData']);

function sendDataToParent() {
  emit('sendData', inputData.value);
}
</script>

<style scoped>
/* 可选的样式部分 */
</style>

代码解释

1,在 <template> 部分,我们创建了一个输入框和一个按钮。

2,在 <script setup> 部分,使用 ref 创建了响应式变量 inputData,用于存储用户输入的数据。

3,通过 defineEmits 定义了 sendData 事件。

4,sendDataToParent 方法会通过 emit 函数将 inputData 变量的值发送给父组件。

相关推荐
布局呆星20 小时前
Vue3 路由守卫详解:全局守卫、路由独享守卫、组件内守卫
前端·javascript·vue.js
小李子呢021120 小时前
前端八股Vue---ref操作 DOM 元素或组件,调用子组件方法
前端·javascript·vue.js
Yoram21 小时前
Vue3 响应性:跨上下文的传递、转换与作用域控制
前端·vue.js
掘金安东尼21 小时前
开源小工具:掘金福利页「补签卡」按次数自动兑换(Chrome 扩展)
前端·开源
Mike_jia21 小时前
Sirius Scan:开源漏洞扫描利器,重塑企业安全防护体系
前端
知兀21 小时前
【前端】默认导出和命名导出区别
前端
XS03010621 小时前
Servlet+JQuery实现数据库数据渲染到前端页面
前端·servlet·jquery
yqcoder21 小时前
深入理解 JavaScript:什么是可迭代对象 (Iterable)?
开发语言·javascript·网络
van久21 小时前
Day27:菜单管理 + 动态路由(前端可直接用!)
前端·状态模式
恋猫de小郭21 小时前
DeepSeek V4 Flash 可以在 128GB 的 M3 Max 运行,还是 1M 上下文
前端·人工智能·ai编程