adv996 2022-05-17 10:11 采纳率: 50%
浏览 48
已结题

VueJS自己实现监视方法的疑问

问题遇到的现象和发生背景

VueJS中想模拟一个监视的方法,使用一个方法,处理前将数据存入oldData,处理后将newData和oldData进行比较

问题相关代码,请勿粘贴截图
methods: {
        change(e) {
            var oldData = this.dataList[e.target.id]  //将处理前的对象赋值给临时对象
            console.log("处理前:", oldData.isDis)   //输出false
            this.dataList[e.target.id].isDis = !this.dataList[e.target.id].isDis // 数据处理
            console.log("处理后:", oldData.isDis)  //输出true  有变化
            var newData = this.dataList[e.target.id]  
            console.log("old:", oldData.isDis, "new:", newData.isDis)  //新旧数据  无变化
        },
}
运行结果及报错内容

输出:
处理前: false
处理后: true
old: true new: true

我的解答思路和尝试过的方法

难道处理前的赋值,是一个指针么?

我想要达到的结果

我的意图是:处理前赋值一个临时对象,处理后把临时对象和改变后的对象进行比较,以判断对象内哪个数据发生了改变

  • 写回答

3条回答 默认 最新

  • CSDN专家-showbo 2022-05-17 10:48
    关注

    看代码oldData 是对象,地址引用,修改对象属性值后,所有引用到这个对象的变量,被修改的属性值都会变。

                var isDis = this.dataList[e.target.id].isDis  //将处理前的对象赋值给临时对象
                var oldData = JSON.parse(JSON.stringify(this.dataList[e.target.id]));///生成新对象
    
                console.log("处理前:", oldData.isDis)   //输出false
                this.dataList[e.target.id].isDis = !this.dataList[e.target.id].isDis // 数据处理
                console.log("处理后:", oldData.isDis)  //输出true  有变化
                var newData = this.dataList[e.target.id]
                console.log("old:", oldData.isDis, "old:", isDis, "new:", newData.isDis)  //新旧数据  无变化
    
    

    img


    有其他问题可以继续交流~

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 5月25日
  • 已采纳回答 5月17日
  • 创建了问题 5月17日

悬赏问题

  • ¥15 如何在scanpy上做差异基因和通路富集?
  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog