vue3父子组件传值怎么实现,与vue2中有何不同
Admin 2022-07-07 群英技术资讯 398 次浏览
现在距离vue3的诞生已经过了很长时间了,笔者也是近期才开始学习vue3。对比vue2来看,vue3在写法发生了不小的变化,最典型的例子就是vue3通过ref,或者reactive实现数据的响应式。因为ref和reactive的出现,使得vue3中父子组件的传值方式也发生了变化
咱们先看下vue2中的写法
父组件:
<!-- 父组件 --> <template> <div> <children :title="title" @getChildren="getChildren"></children> <div>子组件说: {{ childrenAsk }}</div> </div> </template> <script> import children from "./children.vue" export default { data() { return { title: "我是父组件传过来的值", childrenAsk: "" } }, methods: { getChildren(val) { this.childrenAsk = val } } } </script>
子组件:
<!-- 子组件 --> <template> <div> <div>父组件传过来的值: {{ title }}</div> <button @click="askToFather">点击发送给父组件</button> </div> </template> <script> export default { props: { title: { type: String } }, data() { return { askMsg: "这是我给父组件说的话" } }, methods: { askToFather() { this.$emit("getChildren", this.askMsg) } } } </script>
在vue2中,子组件向父组件传值通过this.$emit的形式实现,但是vue3中,是不存在this的,vue3中将数据和函数都封装在了setup中,那么vue3是怎么实现的呢?
我们知道vue3中的setup接收两个参数,第一个参数是props,即父组件向子组件传递的props值,第二个值为context,这个值代表了当前的上下文对象,知道这个东西以后现在来实现vue3的父子组件传值
vue3中父传子和vue2中的父传子一样,再次不做过多阐述,下面重点关注的是vue3的子传父
父组件
<template> <div style="color: aqua">父组件</div> <div>子组件对我说:{{ children_msg }}</div> <children :title="msg" @listen="listenToChildren"></children> {{ value }} </template> <script lang="ts"> import children from "@/views/component_emit/children.vue" import { defineComponent, ref } from "vue" export default defineComponent({ components: { children, }, name: "father", setup() { let msg = "我是父组件" let children_msg = ref("") // ref的作用是实现响应式, 如果没有ref则不能实现响应式(引用数据类型用reactive) let listenToChildren = (val) => { children_msg.value = val // 使用ref包裹的数据,需要通过.value的形式访问他的值 } return { msg, children_msg, listenToChildren, } }, }) </script> <style></style>
子组件:
<template> <div style="color: brown">子组件</div> <!-- 父传子使用方法和vue2相同 --> <div>父组件传过来的值为:{{ title }}</div> <button @click="sayToFather">向父组件说话</button> </template> <script lang="ts"> import { defineComponent } from "vue" export default defineComponent({ name: "children", props: { title: { type: String, }, }, setup(props, context) { // context作用是获取上下文对象, // 如果setup写法为setup(props, { emit })的方式的话,下面的context可以省略 const sayToFather = () => { const ask = "我是子组件,我对父组件说话" context.emit("listen", ask) } return { sayToFather, } }, }) </script> <style></style>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
用jquery可以加样式,方法:1、使用“$(元素).attr("style","行内样式代码")”语句;2、使用“$(元素).css({"属性名":"属性值"})”语句;3、使用“$(元素).addClass("class名称")”语句。
判断方法:1、用“输入控件对象.value”语句获取用户输入的数据;2、用“var re = /^[0-9]+.?[0-9]*/;”语句定义正则表达式对象;3、用“re.test(输入数据)”语句通过正则表达式判断输入数据是否为数值类型。
这篇文章给大家分享的是jQuery怎样对文本框字数限制的方法。一般的文本输入框都是有字数限制的,下文我们尝试用jQuery怎样计算输入字数及控制和限制字数,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
这篇文章主要给大家介绍keep-alive,keep-alive的设计初衷就是为了保持组件的状态,避免组件的重复渲染,那么keep-alive是如何保持组件状态的呢?为什么keep-alive可以直接使用?下面我们来具体的了解看看。
Node.js中怎么使用Redis?下面本篇文章给大家介绍一下Node.js中使用Redis的方法,你会发现原来这么简单,希望对大家有所帮助!
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008