如何解决子组件不能修改父组件传来的值的需求 报错报错Avoid mutating a prop directly since the value will be overwritten wheneve

本文主要是介绍如何解决子组件不能修改父组件传来的值的需求 报错报错Avoid mutating a prop directly since the value will be overwritten wheneve,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、官方文档:
  • 二·、具体的解决方法实现:
  • 总结


前言

报错Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders. Instead, use a data or computed property based on the prop’s value. Prop being mutated: “status” 父组件通过props传值给子组件,如何解决因为在子组件改变props传来的值导致的报错呢?

一、官方文档:

在vue关于props的文档中,父子组件中的数据流是单向的,为什么是单向的呢,其实这是比较合理的,要是双向的话,当我们某个子组件对父组件的值进行了操作,就会导致这个父组件下的所有子组件的值都发生改变,所以文档中给出了下面子组件操作数据时的解决方法。
在这里插入图片描述

二·、具体的解决方法实现:

从组件信息的单向流动,我们知道报错的原因了,但是我们在使用中确实需要对这个父组件传来的值进行更改的话,需要如何实现呢?

  • 第一步:在子组件中接收到父组件的值
  props: {searchKey: {type: String,default: null},stateCategory: {type: String,default: null}},
  • 第二步:在子组件中创建新的局部变量,并且把从父组件获取到的值赋给新的变量
  data(){return {searchWord: this.searchKey,stateCategoryValue: this.stateCategory,},
  • 第三步:创建监听,只要父组件传来的值发生变更就重新赋值给子组件的局部变量,同时创建子组件和父组件的联系,用来把子组件更新的值同步到父组件
  watch: {searchKey(value) {this.searchWord = value;},searchWord(value) {this.$emit('update:searchKey', value);},stateCategory(value) {this.stateCategoryValue = value;},stateCategoryValue(value) {this.$emit('update:stateCategory', value);}},
  • 第四步:到这里就大功告成了,我们可以使用我们创建的局部变量,同时保证我们需要的效果
<el-inputv-model="searchWord"v-trim="searchWord"/><el-selectv-model="stateCategoryValue"v-trim="stateCategoryValue"/>

这里补充一点:

要是我们的值是对象的话,就不能直接赋值了,需要用到深拷贝来获取到,众所周知,对象的话赋值只是把在栈里面的引用地址赋值给它,实际数据是存在堆内存的。


总结

vue的论坛里有讨论过这个问题,一些别的解决方法可以去了解一下,下次有空,我也会尝试使用别的方法来实现效果。但是我们记住一句话:永远不要在子组件中修改父组件的数据!!

这篇关于如何解决子组件不能修改父组件传来的值的需求 报错报错Avoid mutating a prop directly since the value will be overwritten wheneve的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/198236

相关文章

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

解决JSONField、JsonProperty不生效的问题

《解决JSONField、JsonProperty不生效的问题》:本文主要介绍解决JSONField、JsonProperty不生效的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录jsONField、JsonProperty不生效javascript问题排查总结JSONField

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

Oracle修改端口号之后无法启动的解决方案

《Oracle修改端口号之后无法启动的解决方案》Oracle数据库更改端口后出现监听器无法启动的问题确实较为常见,但并非必然发生,这一问题通常源于​​配置错误或环境冲突​​,而非端口修改本身,以下是系... 目录一、问题根源分析​​​二、保姆级解决方案​​​​步骤1:修正监听器配置文件 (listener.

Linux中修改Apache HTTP Server(httpd)默认端口的完整指南

《Linux中修改ApacheHTTPServer(httpd)默认端口的完整指南》ApacheHTTPServer(简称httpd)是Linux系统中最常用的Web服务器之一,本文将详细介绍如何... 目录一、修改 httpd 默认端口的步骤1. 查找 httpd 配置文件路径2. 编辑配置文件3. 保存