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;
},
相关推荐
天意pt4 小时前
Blog-SSR 系统操作手册(v1.0.0)
前端·vue.js·redis·mysql·docker·node.js·express
清风ai明月4 小时前
在vue3中Promise是什么
vue.js
毕设源码-邱学长4 小时前
【开题答辩全过程】以 基于VUE的打车系统的设计与实现为例,包含答辩的问题和答案
前端·javascript·vue.js
麦麦大数据5 小时前
J009 美食推荐可视化大数据系统vue+springboot
vue.js·spring boot·mysql·推荐算法·美食·可视化分析·沙箱支付
rfidunion5 小时前
springboot+VUE+部署(1。新建项目)
java·vue.js·spring boot
Irene19915 小时前
在 Vue 中使用 TypeScript 的几种方式
vue.js·typescript
唯情于酒6 小时前
Docker部署若依(前后端分离版)
vue.js·docker·容器
hhcccchh6 小时前
学习vue第八天 Vue3 模板语法和内置指令 - 简单入门
前端·vue.js·学习
yyf198905256 小时前
Vue 框架相关中文文献
前端·javascript·vue.js
粥里有勺糖6 小时前
开发一个美观的 VitePress 图片预览插件
前端·vue.js·vitepress