本周精读的文章是 Mastering JS console.log like a Pro,一块儿来更全面的认识 console 吧!javascript
console 的功能主要在于控制台打印,它能够打印任何字符、对象、甚至 DOM 元素和系统信息,下面一一介绍。前端
直接打印字符,区别在于展现形态的不一样:java
<img width=400 src="https://img.alicdn.com/tfs/TB1xZ_WveH2gK0jSZFEXXcqMpXa-1492-566.png">git
新版 chrome 控制台能够将打印信息分类:github
<img width=200 src="https://img.alicdn.com/tfs/TB1fZ2Vvhn1gK0jSZKPXXXvUXXa-420-446.png">chrome
log()
与 info()
都对应 info
,warn()
对应 warnings
,error()
对应 errors
,而 debug()
对应 verbose
,所以建议在合适的场景使用合适的打印习惯,这样排查问题时也能够有针对性的筛选。设计模式
好比调试信息能够用 console.debug
仅在调试环境下输出,调试者即使开启了调试参数也不会影响正常 info
的查看,由于调试信息都输出在 verbose
中。浏览器
以下所示,可经过占位符在一行中插入不一样类型的值:性能优化
<img width=400 src="https://img.alicdn.com/tfs/TB1GtL3vlr0gK0jSZFnXXbRRXXa-1840-504.png">微信
<img width=400 src="https://img.alicdn.com/tfs/TB1eK23vlr0gK0jSZFnXXbRRXXa-1832-978.png">
能够总结出,console 支持输出复杂的内容,其输出能力堪比 HTML,但输入能力太弱,仅为字符串,所以采用了占位符 + 多入参修饰的设计模式解决这个问题。
按 JSON 模式输出。笔者在这里也补充一句:console.log()
会自动判断类型,若是内容是 DOM 属性,则输出 DOM 树,但 console.dir
会强制以 JSON 模式输出,用在 DOM 对象时可强制转换为 JSON 输出。
<img width=400 src="https://img.alicdn.com/tfs/TB1KQY1vbj1gK0jSZFuXXcrHpXa-922-302.png">
按照 HTML ELements 结构输出:
<img width=400 src="https://img.alicdn.com/tfs/TB1mZ61va61gK0jSZFlXXXDKFXa-920-255.png">
这种输出结构和 Elements 打印形式是一致的,若是要看详细属性,可使用 console.dir()
。
在控制台打印一个表格,属于功能加强。虽然仅文本也能够在控制台打印出漂亮的表格,但浏览器调试控制台的功能更强大,console.table
只是其富文本能力的一个体现。
<img width=400 src="https://img.alicdn.com/tfs/TB1WldouKbviK0jSZFNXXaApXXa-928-742.png">
接下来是另外一个富文本能力,按分组输出:
<img width=400 src="https://img.alicdn.com/tfs/TB1UV6UvXY7gK0jSZKzXXaikpXa-919-377.png">
这种带有反作用的 API 显然是为方便阅读而设计的,然而在须要输出大量动态结构化数据的场景下,还须要进行结构转换,是比较麻烦的地方。
count()
用来打印调用次数,通常用在循环或递归函数中。接收一个 label
参数以定制输出,默认直接输出 1 2 3
数字。
<img width=400 src="https://img.alicdn.com/tfs/TB1ELLVveL2gK0jSZPhXXahvXXa-917-500.png">
console
版断言工具,当且仅当第一个参数值为 false
时才打印第二个参数做为输出。
<img width=400 src="https://img.alicdn.com/tfs/TB1HEDUvfb2gK0jSZK9XXaEgFXa-1842-548.png">
这种输出结果为 error,因此也可被 console.error
+ 代码级别断言所取代。
打印此时的调用栈,在打印辅助调试信息时很是有用。
<img width=400 src="https://img.alicdn.com/tfs/TB1Jh_YvkL0gK0jSZFAXXcA9pXa-1840-1096.png">
打印代码执行时间,性能优化和监控场景比较常见。
<img width=400 src="https://img.alicdn.com/tfs/TB1wAT2vbj1gK0jSZFuXXcrHpXa-1612-524.png">
打印内存使用状况。
<img width=400 src="https://img.alicdn.com/tfs/TB1tPHYvkL0gK0jSZFAXXcA9pXa-1842-440.png">
清空控制台输出。
console
提供了如此多的输出规范,其实也是在变相制定开发规范,毕竟离开发者最近的就是调试控制台,若是你的项目打印规范与标准规范有差别,那么调试时信息看起来就会很别扭。
能够看到,大部分开源库都良好的遵循了这套规范,好比三方库毫不会输出 log()
,并且将错误、警告与调试信息正确分开,并尽可能少的用 CSS 样式、分组、table
等功能,由于这些功能干扰性较强,不能保证全部用户均可接受。
相对的,项目源码就比较适合使用一些醒目的自定义规范,只要这套规则能被很好的执行起来。
最后留下一个讨论点:console
能够做为调试、招聘信息、隐藏菜单的投放点,你还看到过哪些有意思的 console
使用方式呢?欢迎留言。
讨论地址是: 精读《精通 console.log》 · Issue #228 · dt-fe/weekly
若是你想参与讨论,请 点击这里,每周都有新的主题,周末或周一发布。前端精读 - 帮你筛选靠谱的内容。
关注 前端精读微信公众号
<img width=200 src="https://img.alicdn.com/tfs/TB165W0MCzqK1RjSZFLXXcn2XXa-258-258.jpg">
版权声明:自由转载-非商用-非衍生-保持署名( 创意共享 3.0 许可证)