当前位置: 首页 > news >正文

Vue前端开发子组件向父组件传参

在父组件中,如果需要获取子组件中的数据,有两种方式,一种是在子组件中自定义事件,父组件绑定该事件,当触发自定义事件时,向父组件传入参数;另一种是先通过ref属性给子组件命名,然后在父组件中就可以调用$refs对象,访问命名的子组件中数据。

子组件自定义事件传参

父组件通过绑定子组件中自定义的事件,在触发的事件中,获取传入的数据,这种方式是子组件向父组件传参的重要方式,接下来通过一个实例来演示它实现的过程。

实例7-2 子向父组件传参

1. 功能描述

在实例7-1的基础之上,向子组件的视图中添加一个“长度”按钮,当点击该按钮时,获取父组件传入数据的长度,并通过自定义的事件,将该长度值传递给父组件,父组件接收该值后,显示在页面中。

2. 实现代码

在项目的components 文件夹中,添加一个名为“Parent”的.vue文件,该文件的保存路径是“components/ch7/part2/”,在文件中加入如清单7-3所示代码。

代码清单7-3 Parent.vue代码

<template><div class="iframe"><div class="i-left"><span>父组件:</span><input v-model="name" placeholder="请输入用户名" /></div><div class="i-right">{{ len }}</div></div><!-- 在父组件中调用子组件 --><Child :inputName="name" @getLength="onGetLength" />
</template>
<script>
import Child from "./Child.vue"
export default {data() {return {name: "",len: 0}},components: {Child},methods: {onGetLength(data) {this.len = data}}
}
</script>
<style>
.iframe {width: 300px;display: flex;justify-content: space-between;align-items: center;padding: 8px;border: solid 1px #ccc;
}.i-left {display: flex;align-items: center;
}.iframe input {padding: 8px;
}.iframe:last-child {border-top: none;padding: 16px 8px;background-color: #eee;
}
</style>

在父组件中,导入并注册了一个名称为Child的子组件,它的功能是通过自定义的事件向父组件传递数据,并将该数据显示在视图模块中,它的代码如清单7-4所示。

代码清单7-4 Child.vue代码

<template><div class="iframe"><div class="i-left"><span>子组件:</span><span>{{ inputName }}</span></div><div class="i-right"><button @click="onGetLength">长度</button></div></div>
</template>
<script>
export default {props: {inputName: {type: String,required: true}},emits: ["getLength"],methods: {onGetLength() {this.$emit("getLength", this.inputName.length)}}
}
</script>

3. 页面效果

保存代码后,页面在Chrome浏览器下执行的页面效果如图7-3所示。
在这里插入图片描述

4. 源码分析

在子组件Child的源码中,为了能向父组件传递参数,先在“emits”选项中定义一个名为“getLength”的事件,当点击“长度”按钮时,执行该事件,同时,将inputName数据的长度值作为事件携带的参数。

在父组件Parent的源码中,为了能接收到子组件传入的参数,则在调用子组件时,绑定自定义的“getLength”事件,并在事件执行时,获取携带的参数值,并将该值作为变量,绑定到视图的元素中,从而最终实现子组件向父组件传参的过程。

需要说明的是:自定义事件携带的参数可以是一个变量,也可以是一个对象,如果需要传递多项数据,则可以借助对象的形式向父组件传递。
在这里插入图片描述

http://www.lryc.cn/news/488051.html

相关文章:

  • javaScript语法基础(函数,对象,常用类Array,String,Math和Date)
  • WebStorm 2022.3.2/IntelliJ IDEA 2024.3出现elementUI提示未知 HTML 标记、组件引用爆红等问题处理
  • k8s-NetworkPolicy
  • 【C++】踏上C++学习之旅(九):深入“类和对象“世界,掌握编程的黄金法则(四)(包含四大默认成员函数的练习以及const对象)
  • C++——智能指针剖析
  • 241119.LeetCode——383.赎金信
  • 基于SSM的农家乐管理系统+论文示例参考
  • 用 Python 从零开始创建神经网络(九):反向传播(Backpropagation)(还在更新中。。。)
  • Flink是如何实现 End-To-End Exactly-once的?
  • 【vulhub】nginx解析漏洞(nginx_parsing_vulnerability)
  • 网络协议之邮件协议(SMTP、POP3与IMAP)
  • python学习笔记(3)运算符
  • _FYAW智能显示控制仪表的简单使用_串口通信
  • 激光雷达定位初始化的另外一个方案 通过键盘按键移动当前位姿 (附python代码)
  • 从0-1逐步搭建一个前端脚手架工具并发布到npm
  • 河道水位流量一体化自动监测系统:航运安全的护航使者
  • 维护在线重做日志
  • ASCB1系列APP操控末端回路智能微断 物联网断路器 远程控制开关 学校、工厂、农场、商业大楼等可用
  • Python入门(10)--面向对象进阶
  • Makefile 之 自动化变量
  • 鸿蒙开发:ForEach中为什么键值生成函数很重要
  • 沃丰科技智能外呼机器人:超越人工,重塑外呼体验
  • 百度飞浆:paddle 线性回归模型
  • 【JavaSE】【网络编程】UDP数据报套接字编程
  • 45.坑王驾到第九期:Mac安装typescript后tsc命令无效的问题
  • 20241120-Milvus向量数据库快速体验
  • 【Golang】——Gin 框架中间件详解:从基础到实战
  • 量子计算来袭:如何保护未来的数字世界
  • VMware虚拟机(Ubuntu或centOS)共享宿主机网络资源
  • 光伏电站仿真系统的作用