Skip to content

Latest commit

 

History

History
77 lines (46 loc) · 4.34 KB

README.md

File metadata and controls

77 lines (46 loc) · 4.34 KB

浏览器 Console 高级技巧实战

课程介绍

console 是开发 javascript 应用时最常用的调试工具,也是大多前端工程师入门时学会的第 1 个 API。除 console.log 之外,现代浏览器还为我们提供了很多打印日志的函数,来简化开发中的各种日志输出需求,比如日志分级、格式化、分组、计时、计数等。花 15 分钟学完本课程,你就能把这些工具函数添加到你的工具箱,让自己成为更高效的工程师。

适用人群

  • [required]具备前端基础知识,CSS、HTML、JS;
  • [optional]用 Chrome 调试代码,但调试时只用 console.log 的同学;
  • [optional]期望不断打磨自己的调试技能,让自己变得更值钱;

内容目录

1. 日志级别及其语义化方法

类似于后端开发的日志分级,console 对象也提供了不同日志级别输出的各种函数,使用这些函数,能够让你打印的日志简洁,更容易阅读过滤。

2. 使用 console.log 高级参数

只用 console.log 输出简单的字符串?学完这节课你可以做的更多:输出多个参数,输出类似于 C 语言风格的模板变量替换,甚至输出有样式的日志。

3. 使用 console.group* 做日志分组和嵌套

调试时需要输出大量的日志?但是日志扫读确很费劲?console.group 能帮你更好的组织日志,实现页面里面才有的分组、折叠,甚至是嵌套。

4. 警惕 console.assert 的便利

console.assert 让你不用 if 就能判断条件并输出日志,很有用,但行为和你所熟知的其他语言并不完全相同,什么时候该用?什么时候不该用?

5. 使用 console.count 计数

抛弃临时变量计数法,因为 console.count 就能帮你统计感兴趣事件发生的次数。

6. 使用 consome.time* 计时

在性能诊断和优化时你还在自定义各种 timer 和临时变量?结合 console.timeconsole.timeEnd 为任何 javascript 操作计时,这样就不会出现临时变量污染代码库了。

7. 使用 console.table 输出结构化数据

console.table 能够让结构化的数据输出可读性更高,不仅支持对象和数组,并且允许你自定义输出的列。

8. 使用 console.trace 调试复杂代码

console.trace 能够让你在不终止代码执行的情况下知道代码的执行路径,即打印出代码的调用栈,这点在调试复杂代码时非常有用。

源码链接

仓库地址:wangshijun/course-advanced-console-logging

运行方法(确保系统中安装了 gulp 命令行工具):

git clone https://github.com/wangshijun/course-advanced-console-logging.git
cd course-advanced-console-logging
gulp serve

如果想运行某节课的源码,直接修改 app/index.html 第 53 行的脚本引用地址,对应的代码如下:

  1. 日志级别及其语义化方法
  2. 使用 console.log 高级参数
  3. 使用 console.group* 做日志分组和嵌套
  4. 警惕 console.assert 的便利
  5. 使用 console.count 计数
  6. 使用 consome.time* 计时
  7. 使用 console.table 输出结构化数据
  8. 使用 console.trace 调试复杂代码

运行环境

  • Chrome v61
  • Node.js v8.6

参考资料