Vue解决父子组件传值,子组件改变值后父组件的值也改变的问题

vue开发过程中,父组件通过props传值给子组件,子组件在页面展示父组件的值,在操作子组件值以后,即使不点击确定按钮,父组件中的值也发生了变化,但是需求是操作子组件数据以后,必须点击"确定"按钮以后才能修改父组件的值,否则父组件和子组件的值都不可以变化。

为了解决这一问题,当父组件传值给子组件以后,我通过JSON.parse(JSON.stringify(data ))将父组件的数据进行拷贝,然后赋值给子组件中this.targetdData,子组件操作也是改变的this.targetData的值,而不会改变父组件的值,当点击"确定"按钮时,通过$emit调用父组件中的函数,将修改后的this.targetData值给了父组件,修改父组件中的值,当再次进入子组件的时候,会重新把修改后的值拷贝给子组件进行展示就可以解决上述问题了。

拷贝父组件的值:

javascript 复制代码
this.targetData = JSON.parse(JSON.stringify(this.targetDataPar))

调用父组件方法:

复制代码
this.$emit('changeData', this.targetData)

父组件的方法:

复制代码
changeData(val) {
      this.targetChanged = val;
},
相关推荐
小李子呢021119 分钟前
前端八股Vue(6)---v-if和v-for
前端·javascript·vue.js
周星星日记1 小时前
vue3中静态提升和patchflag实现
前端·vue.js·面试
军军君012 小时前
Three.js基础功能学习十五:智能黑板实现实例二
开发语言·前端·javascript·vue.js·3d·threejs·三维
IT枫斗者2 小时前
构建具有执行功能的 AI Agent:基于工作记忆的任务规划与元认知监控架构
android·前端·vue.js·spring boot·后端·架构
hotlinhao2 小时前
Nginx rewrite last 与 redirect 的区别——Vue history 模式短链接踩坑记录
前端·vue.js·nginx
weixin_461769403 小时前
npm create vue@latest 错误
前端·vue.js·npm
写不来代码的草莓熊3 小时前
el-date-picker ,自定义输入数字自动转换显示yyyy-mm-dd HH:mm:ss格式
前端·javascript·vue.js
风之舞_yjf4 小时前
Vue基础(31)_插件(plugins)、scoped样式
前端·vue.js
M ? A4 小时前
Vue3+TS实战避坑指南
前端·vue.js·经验分享