vue组件传值报错: Instead, use a data or computed property based on the prop‘s value. Prop being mutated: “

本文介绍了在Vue中遇到的单选组件修改父组件prop值导致的错误,以及两种解决方案。一是通过在子组件中创建中间变量同步父组件传递的值,二是利用`.sync`修饰符结合`$emit`更新父组件状态。这两种方法有效地遵循了Vue的单向数据流原则。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题

问题:在单选组件(radio)切换后,修改了来自父组件的值(item),然后报错如下:

在这里插入图片描述

原因

prop是单向绑定,不能更改数据,只能由父组件传输过来

解决

1、可以在子组件中 声明一个中间变量(value),把父组件传过来的值(item)赋值给中间变量(value),当单选切换时修改的数据为value,就不会报错

2、使用.sync修饰符与$emit(update:xxx)

父组件

<comp :item.sync="item"></comp>

子组件

this.$emit('update:item',data)
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值