Vue父子组件属性传递实现方法详解
更新时间:2023年02月08日 09:03:56 作者:Zong_0915
这篇文章主要介绍了Vue父子组件属性传递实现方法,我们主要从案例出发,用Vue3的写法写父子组件之间的属性传递,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
前言
这节我们主要从案例出发,用Vue3
的写法写父子组件之间的属性传递。
组件之间属性的传递
我们定义一个Rate
组件,具有以下功能:
- 接收来自外部组件传入的参数,
starCount
代表星星个数。color
代表星星颜色。 - 需要根据传入星星的个数,展示对应数量的星星。
父组件传递属性给子组件
那么在编写组件的时候,我们需要注意什么?
- 我们可以使用
defineProps
来规范传递数据的格式。可以结合withDefaults
来进行默认值的赋值。 - 如果是响应式数据的传递,在传递给子组件的时候,需要添加前缀
:
。如果是常量,则不用。
我们在components
目录下创建完Rate.ts
文件后。完整代码如下:
<template> <div :style="fontstyle"> {{ rate }} </div> </template> <script setup lang="ts"> import { computed, defineProps, withDefaults } from "vue"; // 定义父组件传入的参数类型 interface Props { starCount: number; color: string; } // 规定传值类型以及赋上默认值 let props = withDefaults(defineProps<Props>(), { starCount: 0, color: "blue", }); // 凡是计算有关的,我们都用computed来包装 const rate = computed(() => "★★★★★☆☆☆☆☆".slice(5 - props.starCount, 10 - props.starCount) ); const fontstyle = computed(() => { return `color:${props.color};`; }); </script>
外部组件调用如下:
<template> <Rate starCount="3"></Rate> <Rate starCount="4" color="red"></Rate> <Rate starCount="1" color="green"></Rate> </template> <script setup> import Rate from "./components/Rate.vue"; </script>
最终效果如下:
子组件传递属性给父组件
我们在编写组件的时候,我们需要注意什么?
- 子组件:需要通过
defineEmits
函数,注册一个自定义事件或者其他事件,例如click
事件。然后手动触发emit
函数,调用该自定义事件,并传递参数。 - 父组件:引用子组件的时候,通过
v-on
绑定一个函数,指向子组件里面定义的事件。注意:v-on
的效果等同于@
符号。
定义一个子组件Son
:
<template> <div style="margin: 10px; border: 2px solid red"> 我是子组件 <button @click="transValue" style="margin: 5px;background:#caca88">传值给父组件</button> </div> </template> <script setup lang="ts"> import { ref } from "vue"; // 定义所要传给父组件的值 const num = ref<number>(0); // 使用defineEmits注册一个自定义事件 const emit = defineEmits(["getValue"]); // 点击事件触发emit,去调用我们注册的自定义事件getValue,并传递value参数至父组件 const transValue = () => { num.value++; emit("getValue", num.value); }; </script>
父组件Father
:
<template> <div class="fa"> <div style="margin: 10px;">我是父组件</div> 父组件接收子组件传的值:{{sonMessage}} <Son @getValue="getSonValue"></Son> <!-- <Son v-on:getValue="getSonValue"></Son> --> </div> </template> <script setup lang="ts"> import Son from './Son.vue' import {ref} from "vue"; const sonMessage = ref<String>('0') const getSonValue = (value: String) => { sonMessage.value = value } </script> <style scoped> .fa{ border: 3px solid cornflowerblue; width: 400px; text-align: center; } </style>
运行效果如下:
到此这篇关于Vue父子组件属性传递实现方法详解的文章就介绍到这了,更多相关Vue父子组件属性传递内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue中使用crypto-js AES对称加密算法实现加密解密
在数字加密算法中,通过可划分为对称加密和非对称加密,本文主要介绍了Vue中使用crypto-js AES对称加密算法实现加密解密,文中根据实例编码详细介绍的十分详尽,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2022-03-03vue文件上传Required request part ‘file‘ is&n
这篇文章主要介绍了vue文件上传Required request part ‘file‘ is not present问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-11-11
最新评论