详解前端console.log自定义打印列表图片和调试

前言

在前端开发中,console.log() 是最常用的调试工具,但 console 对象实际上蕴含着丰富的功能。除了基础的日志打印,它还能以表格形式展示数据、为输出添加自定义样式,甚至能在控制台中呈现图片和动图。本文将系统介绍 console 对象的各类实用方法,涵盖调试信息打印、数据可视化、性能监测等多个维度,帮助开发者更高效地利用控制台进行开发调试。

1. 基础信息打印

主要是一些文字信息:

1. 调试信息打印

javascript 复制代码
console.debug('console.debug:调试信息')
  • 应用场景:用于记录开发过程中的调试细节。
  • 显示位置 :在浏览器控制台的 levels 选项中选择 Verbose 级别可见。

2. 普通信息与提示信息

javascript 复制代码
console.log('console.log:普通信息')
console.info('console.info:提示信息')
  • 区别 :在谷歌浏览器中,console.logconsole.info 的显示效果几乎一致,但在其他浏览器中可能存在样式差异(如图标或颜色不同)。

2. 数据可视化展示

可以平铺打印数组和对象等等:

2.1. 表格形式打印

javascript 复制代码
console.table([
  { id: 1, name: '张三', age: 1 },
  { id: 2, name: '李四', age: 2 },
  { id: 3, name: '王五', age: 3 },
  { id: 4, name: '赵六', age: 4 },
]);
  • 优势 :将对象数组或类数组数据以表格形式直观展示,支持点击表头排序,便于调试后端接口返回的数据。

2.2. 分组打印

javascript 复制代码
console.group('信息1')
console.table([
	{ id: 1, name: '张三', age: 1 },
	{ id: 2, name: '李四', age: 2 }
])
console.groupEnd()

console.groupCollapsed('信息2') // 折叠分组
console.table([
	{ id: 3, name: '王五', age: 3 },
	{ id: 4, name: '赵六', age: 4 }
])
console.groupEnd()
  • 功能 :通过分组组织相关日志,避免控制台信息混乱。console.groupCollapsed 可默认折叠分组,节省界面空间。

3. 对象与性能调试

下面方法可用于代码调试和测试等等

3.1. 打印对象结构

javascript 复制代码
console.dir(document.body);
  • 对比console.log(document.body) 仅显示 DOM 元素结构,而 console.dir 可展示对象的所有属性和方法,便于深入分析 DOM 对象或自定义对象的结构。

3.2. 计时功能

javascript 复制代码
console.time("循环start");
const startTime = Date.now();
while (Date.now() - startTime < 1999) {}
console.timeEnd("循环end"); // 输出执行时间
  • 用途 :精确测量代码块的执行耗时,用于性能测试和优化。

3.3. 计数功能

javascript 复制代码
const startTime = Date.now();
while (Date.now() - startTime < 1999) {
  console.count("计数"); // 每次执行时计数加1
}
// 输出:计数: 执行次数
  • 场景:统计函数或循环的执行次数,辅助分析代码运行频率。

4. 调试与错误处理

如下:

4.1. 堆栈跟踪

javascript 复制代码
function funA() {
  console.trace();
}
function funB() {
  funA();
}
funB();
  • 输出示例
scss 复制代码
console.trace
funA                  @index.tsx:187
funB                  @index.tsx:190
handlechangeTabsType  @index.tsx:192
handleclickTabs       @index.tsx:19
onclick               @index.tsx:30
  • 作用 :显示函数调用堆栈,帮助定位代码执行路径,尤其适用于第三方库报错时的问题排查。

4.2. 断言机制

javascript 复制代码
// 断言为false时,会打印错误
console.assert(4 < 2);
  • 注意 :在 Node 环境下,断言失败会中断程序;在浏览器环境中仅打印警告,不中断执行。

4.3. 警告与错误信息

javascript 复制代码
console.warn("这是一个警告信息");
console.error("这是一个错误信息");
  • 显示效果 :警告和错误信息会以特定样式突出显示(如黄色背景或红色图标),便于快速识别异常。

5. 控制台高级操作

如下:

5.1. 清空消息

javascript 复制代码
console.log("a");
console.clear(); // 清空控制台所有历史消息

5.2. 自定义样式输出

javascript 复制代码
const message = '%c带样式的文本';
const style = 'color: red; font-size: 12px; font-weight: bold; border: 1px green solid';
console.log(message, style);
  • 语法 :使用 %c 标记样式起始,后续字符串应用对应样式,支持 CSS 样式属性(如颜色、字体、边框等)。

5.3. 控制台打印图片(含动图)

  • 注意事项
    • 有些浏览器不支持直接显示网络地址的图片,需将图片转换为 Base64 格式后放入 background-image
    • 通过 CSS 背景图实现动图显示,需确保图片格式为 GIF 并转换为 Base64。
javascript 复制代码
const image = ''
console.log(
			`%c %c \nCSDN\n%c LOGO %c png `,
			`padding: 20px 40px; background-image: url(${image}); background-size: contain; background-repeat: no-repeat; color: transparent;`,
			'color: #FC5531; font-size: 12px;line-height:24px;',
			'background: #240F74; padding: 2px; border-radius: 4px 0 0 4px; color: #fff',
			'background: #FC5531; padding: 2px; border-radius: 0 4px 4px 0; color: #fff'
		)

6. 总结

console 对象远不止 log 功能,合理运用这些高级方法能大幅提升调试效率:

  • 数据展示console.table 和分组打印让复杂数据结构一目了然;
  • 性能监测timecount 帮助量化代码执行效率;
  • 调试技巧traceassert 辅助定位逻辑错误;
  • 创意应用:自定义样式和图片打印为控制台增添趣味性(如公司 Logo、调试彩蛋)。

7. console插件

这里分享一些console打印的插件,祝你打印出帅气的信息:

  • loglevel:最小轻量级日志记录,添加可靠的日志级别方法来包装任何可用的console.log方法。
  • Turbo Console Log:VsCode插件,直接在VsCode扩展中搜索
  • eruda:移动端浏览器控制台。
  • unplugin-turbo-console: 一个Vite插件,用于在开发时打印更漂亮的控制台日志。

如果看了觉得有帮助的,我是鹏多多,欢迎 点赞 关注 评论;

往期文章

个人主页

相关推荐
掘金安东尼24 分钟前
字节前端三面复盘:基础不花哨,代码要扎实(含高频题解)
前端·面试·github
吃奥特曼的饼干31 分钟前
React useEffect 清理函数:别让依赖数组坑了你!
前端·react.js
烛阴39 分钟前
TypeScript 函数重载入门:让你的函数签名更精确
前端·javascript·typescript
前端老鹰40 分钟前
HTML <meta name="color-scheme">:自动适配系统深色 / 浅色模式
前端·css·html
Keya1 小时前
MacOS端口被占用的解决方法
前端·后端·设计模式
moyu841 小时前
解密Vue组件中的`proxy`:此Proxy非彼Proxy
前端
用户84913717547161 小时前
为什么大模型都离不开SSE?带你搞懂第1章〈SSE技术基础与原理〉
前端·网络协议·llm
随笔记1 小时前
react中函数式组件和类组件有什么区别?新建的react项目用函数式组件还是类组件?
前端·react.js·typescript
在星空下1 小时前
Fastapi-Vue3-Admin
前端·python·fastapi
FogLetter1 小时前
面试官问我Function Call,我这样回答拿到了Offer!
前端·面试·openai