chrome devtools的使用——console面板

1,642 阅读4分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第14天,点击查看活动详情

前言

不知大家对chrome的开发者工具使用的熟练度如何?是否是和我一样只停留在查看输出,查看错误,打断点等一些基础操作上。每次看别人使用和自己使用总感觉是两种工具。所以,今天,就扒一扒chrome 开发者工具的一些操作,让我们的开发效率提起来。

console 面板

console面板, 又称控制台, 用于打印应用信息和输入需要被执行的代码。整个console面板大概分为以下这几个部分,大家这块应该也都熟悉,毕竟接触的最多的可能就是console面板了。 image.png

下面我们来看一下console api

console api

console.assert(expression,object)

当 expression 的结果为true的时候,控制台无显示;当满足expression表达式满足false条件的时候,该消息以及堆栈跟踪被写入控制台。

console.assert(1 > 1"false");
// Assertion failed: false
console.assert(1 > 0, "false");
// undefined

console.clear()

清除控制台信息,如果setting(设置)中"Preserve Logs"(保持日志)是打开状态时,console.clear()失效

console.count(label)

打印出这个方法被执行的次数。在调试js执行的时候挺有帮助,可以结合console.time(label) console.timeEnd(label)结合,看某函数执行的次数及每次执行所耗的时间。

function showCount(){
    console.count("call");
}
showCount();   // call: 1
showCount();   // call: 2
showCount();   // call: 3

console.dir(object)

打印指定对象的JSON表示形式。这个方法比较实用,可以将DOM元素转为 js 对象打印,增强可读性。

image.png

console.countReset([label])

重置计数

console.count();  // default: 1
console.count('coffee');  // coffee: 1
console.count('coffee');  // coffee: 2
console.count();  // default: 2


// 重置上面代码的打印结果
console.countReset();
console.countReset('coffee');
console.count();  // default: 1
console.count('coffee');  // coffee: 1

console.group(object[,object,...])

根据可选的标题产生一个新的日志列表,之后直至console.groupEnd()之前的控制台输出信息都会列在这个日志组中,如果没使用console.groupEnd()进行闭合,则之后的输出将都包括在这个日志组中。

console.group("g");
console.log(1);
console.dir(document.body);
console.groupEnd("g");
console.log(2);
/*
g
|-- 1
|-- DOM对象(body)
-
2
*/

console.groupCollapsed(object[, object, ...])

console.group(object[,object,...])使用方式相同,不同的是console.group(object[,object,...])打印的日志组的状态是打开的,而console.groupCollapsed(object[, object, ...])打印的是闭合的日志组。

console.log(object [, object, ...])

在控制台打印信息。你可以在这个方法中传入一个或多个对象,每个对象会通过计算后加入一串使用空格分隔的字符串。传入的第一个参数可能会包含格式说明符号,该说明符号由一个百分号(%)后加一个代表需要被替换内容的字母。

  • %s 字符串
  • %d or %i 整数
  • %f 浮点数
  • %o 可扩展DOM元素(在element面板一样)
  • %O 可扩展javascript元素
  • %c 根据提供的css样式输出字符串

感觉都不认识log了,hh。 image.png

console.error(object [, object, ...])

以报错的格式打印信息,并且在调用列出产生堆栈跟踪。

console.info(object [, object, ...])

以信息的格式打印信息。

console.warn(object [, object, ...])

以警告的格式打印信息。

console.time(label)

开始一个新的带有标签的计时器。在之后的代码中调用console.timeEnd(label)时,停止计时并且将所耗时间间打印在控制台。注意:timeEnd的label需要和time的label对应上才算闭合这个计时。


console.time("Array initialize");
let arr = new Array(100),
      len = arr.length,
      i;
for (i = 0; i < len; i++) {
  arr[i] = new Object();
};
console.timeEnd("Array initialize");   // 输出: Array initialize: xxxms

console.trace()

显示当前所执行到的代码处的堆栈跟踪信息。写基础库和组件的时候经常用。

console.table(array[object])

将数组数据(数组元素为对象)以table布局展示。

const data = [
  {id:1, value:"a"},
  {id:2, value:"b"},
  {id:3, value:"c"},
  {id:4, value:"d"},
  {id:5, value:"e"},
  {id:6, value:"f"}
];
console.table(data);

image.png

$相关

以下api基于该代码片段:

<div id="nav" index="0"></div>
<div class="nav" index="1"></div>
<div class="nav" index="2"></div>
<div class="nav" index="3"></div>
<script>
  const obj = {value:1};
</script>

$()

返回符合css选择器条件的第一个元素,是 document.querySelector() 的简写。

$('#nav')
// <div id="nav" index="0"></div>(html元素)
$('.nav')
// <div class="nav" index="1"></div>(html元素) 注意:这里取的是class含有nav样式的元素列表中的第一个元素

$$()

返回符合css选择器条件的所有元素组成的数组,是 document.querySelectorAll() 的封装。

$$('.nav')
// [<div class="nav" index="1"></div>,<div class="nav" index="2"></div>,<div class="nav" index="3"></div>]

$_

返回最近一次计算得出的值,默认undefined。

1+2
// 3
$_
// 3
$$('.nav')
// [<div class="nav" index="1"></div>,<div class="nav" index="2"></div>,<div class="nav" index="3"></div>]
$_
// [<div class="nav" index="1"></div>,<div class="nav" index="2"></div>,<div class="nav" index="3"></div>]
$_.length
// 3

$01234

返回最近5次选中的元素。

  • $0 最近的第一次
  • $1 最近的第二次
  • $2 最近的第三次
  • $3 最近的第四次
  • $4 最近的第五次

一些其他API

inspect()

inspect()函数需要传入一个DOM元素或者javascript引用,如果传入的是DOM元素,开发者工具会跳到Elements面板,并且展示对应的元素;如果传入的是javascript引用,开发者工具跳到Profile面板或者控制台显示堆栈信息。

inspect($('#nav'));

该操作会跳转至 Elements 面板并选中对应的DOM元素。

getEventListeners(object)

返回指定对象上绑定的事件。

image.png

copy(object)

将指定对象的字符串表示形式复制到剪贴板。

monitor(function)

监听指定函数的执行。调用指定的函数时,将消息记录到控制台,该消息指示出函数名以及调用函数时传递给函数的参数。


function sum(x, y) {
    return x + y;
}
monitor(sum);

sum(1,2) // info: function sum called with arguments: 1, 2  output: 3

monitorEvents(object[, events])

监听指定对象上发生的指定事件。事件发生时,事件对象将记录到控制台。

monitorEvents(window, "resize");

image.png

总结

关于console面板的分享就这么多,对我来说,确实好多都没用过。下次分享elements面板,bye~