warisFairy 2023-02-28 16:56 采纳率: 46.3%
浏览 23
已结题

vue __ob__Observer 导致赋值失败


vue __ob__  Observer 导致赋值失败

接口在created调用

赋值的时候需要把数据遍历然后赋值

我在接口请求中打印console.log(JSON.parse(JSON.stringify()))数据是没问题的

但是如果赋值  this.a* = JSON.parse(JSON.stringify(this.a)) 的时候还是没有改变  __ob__  Observer

导致在外部就无法使用到数据
  • 写回答

2条回答 默认 最新

  • CodeBytes 2023-02-28 17:04
    关注

    该回答引用ChatGPT

    ob 是 Vue 内部使用的一个属性,它用来实现 Vue 的响应式系统,当一个对象被 Vue 转换为响应式对象时,Vue 会在对象上添加 ob 属性,同时为对象的属性添加 getter 和 setter 方法,以便能够监听到属性变化并触发视图更新。

    赋值操作应该是在对象被 Vue 转换为响应式对象之后进行的,如果在赋值操作之前打印对象,你会发现对象中并没有 ob 属性,因为此时对象还没有被 Vue 转换为响应式对象。所以,在进行赋值操作之前,你需要先将对象转换为响应式对象,可以通过调用 Vue 实例的 $set 或者 $watch 方法来实现。例如:

    this.$set(this, 'a', JSON.parse(JSON.stringify(this.a)));
    
    

    或者:

    
    this.$watch(() => this.a, (newValue) => {
      this.a = newValue;
    }, { deep: true });
    
    

    这样做可以确保赋值操作能够成功修改对象的属性,并触发视图更新。

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

报告相同问题?

问题事件

  • 系统已结题 3月11日
  • 已采纳回答 3月3日
  • 创建了问题 2月28日

悬赏问题

  • ¥15 在不同的执行界面调用同一个页面
  • ¥20 基于51单片机的数字频率计
  • ¥50 M3T长焦相机如何标定以及正射影像拼接问题
  • ¥15 keepalived的虚拟VIP地址 ping -s 发包测试,只能通过1472字节以下的数据包(相关搜索:静态路由)
  • ¥20 关于#stm32#的问题:STM32串口发送问题,偶校验(even),发送5A 41 FB 20.烧录程序后发现串口助手读到的是5A 41 7B A0
  • ¥15 C++map释放不掉
  • ¥15 Mabatis查询数据
  • ¥15 想知道lingo目标函数中求和公式上标是变量情况如何求解
  • ¥15 关于E22-400T22S的LORA模块的通信问题
  • ¥15 求用二阶有源低通滤波将3khz方波转为正弦波的电路