console.log()控制台异步打印与对象展开后不一致问题

问题描述:

js 复制代码
console.log('baseData', baseData);
console.log('metrics', metrics);
normalizeMetricNulls(baseData, metrics);

上述代码中normalizeMetricNulls这个函数的作用是将bastData中属性值为null的字段修改为0,但是我发现我在这个函数的前面输出了baseData的值,其中的字段值已经是0,按理说还没有修改,应该是null,如下图所示:

解答:

我询问了AI,其给我的解答是:

❗️ Chrome 控制台对对象是按引用显示的(展开时会显示对象的"当前"状态),所以即便你在调用前用 console.log 打印了对象,之后如果对该对象做了修改(比如 normalizeMetricNulls),在控制台展开时会看到修改后的值(看起来像"先打印后修改也显示修改后")。

同时我也得到了解决办法,快照打印,对对象立即序列化,避免引用问题:

js 复制代码
console.log('baseData snapshot', JSON.parse(JSON.stringify(baseData)));
console.log('metrics snapshot', JSON.parse(JSON.stringify(metrics)));
normalizeMetricNulls(baseData, metrics);

其实我这个例子不能说明什么展开前的值和展开后的值的区别,因为我的图片中在控制台展开前的值显示的是省略号,所以我在网上搜到相关的更直白的例子:

(图中riskId展开前后的值不一致!)

❗️ 另一种解决办法就是调试对象的时候,使用debugger来调试效果更好。

参考文章:
前端 - 这个情况是因为什么?控制台输出的对象,在展开和折叠时数据不对等?

什么?console.log打印出的数据竟然不对?都怪我年轻不懂事,调试代码只会用console.log。

附录:

我还尝试了赋值和浅拷贝之后进行打印:

js 复制代码
//赋值
let b = baseData,m = metrics;
console.log('baseData snapshot', b);
console.log('metrics snapshot', m);
//浅拷贝
let b = Object.assign([], baseData), m = Object.assign([], metrics);
console.log('baseData snapshot', b);
console.log('metrics snapshot', m);

以上两种方法都以失败告终,究其原因:

  • 赋值依然引用的同一个对象。
  • 浅拷贝则是当对象只有一级属性为深拷贝;当对象中有多级属性时,二级属性后就是浅拷贝。

赋值,深浅拷贝问题可参考:全排列-遇到的深浅拷贝问题

相关推荐
低代码布道师1 小时前
Next.js 16 全栈实战(一):从零打造“教培管家”系统——环境与脚手架搭建
开发语言·javascript·ecmascript
鹏北海-RemHusband1 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
LYFlied1 小时前
AI大时代下前端跨端解决方案的现状与演进路径
前端·人工智能
光影少年1 小时前
AI 前端 / 高级前端
前端·人工智能·状态模式
一位搞嵌入式的 genius1 小时前
深入 JavaScript 函数式编程:从基础到实战(含面试题解析)
前端·javascript·函数式
anOnion2 小时前
构建无障碍组件之Alert Dialog Pattern
前端·html·交互设计
choke2332 小时前
[特殊字符] Python 文件与路径操作
java·前端·javascript
云飞云共享云桌面2 小时前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
Deng9452013142 小时前
Vue + Flask 前后端分离项目实战:从零搭建一个完整博客系统
前端·vue.js·flask
威迪斯特2 小时前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构