console

console

Console 对象可以接入浏览器控制台(如:Firefox 的 Web Console)。在不同浏览器上它的实现细节可能是不一样的,但这里会介绍一些典型的浏览器会提供的特性。

Console 对象可以从任何全局对象中访问到,如 Window,WorkerGlobalScope 以及控制台属性中的特殊变量。它被定义为 Window.console,而且可直接通过 console 调用。例:

console.log("this is a log");

方法

Console.log() 打印通用的方法

语法

console.log(obj1 [, obj2, ..., objN);

console.log(msg [, subst1, ..., substN);

console.log('String: %s, Int: %d,Float: %f, Object: %o', str, ints, floats, obj)

console.log(temp的值为: ${temp})

// 输出对象
console.log({ test: "test" });

// 输出字符串
console.log("String");

// 指定对象的输出格式
var str = 1,
  ints = -6.3,
  floats = 1.1,
  obj = { test: "test" };
console.log(
  "String: %s, Int: %d, Float: %f, Object: %o",
  str,
  ints,
  floats,
  obj
);
// 控制台输出 String: 1, Int: -7, Float: 1.1, Object: {test: "test"}

// 模板字符串模式
console.log(`String: ${str}`);
// 控制台输出 String: 1

使用字符串替换有以下类型

替换字符串 描述
%o or %O 打印 JavaScript 对象,可以是整数、字符串或是 JSON 数据
%d or %i 打印整数
%s 打印字符串
%f 打印浮点数

为控制台定义样式 ( 你可以使用 %c 为打印内容定义样式 )

console.log(
  "This is %cMy stylish message",
  "color: yellow; font-style: italic; background-color: blue;padding: 2px"
);

输出如图
console_第1张图片
console-style.png

Console.info() 打印资讯类说明信息

向 web 控制台输出一个通知信息。仅在 Firefox,web 控制台的日志中的项目旁边会显示一个小的‘I‘图标

语法

console.info(obj1 [, obj2, ..., objN]);

console.info(msg [, subst1, ..., substN]);

console.info({ info: "info" });
console.info("info1", "info2");
console.info("info");

控制台输出如图
console_第2张图片
console-info.png

Console.warn() 打印一个警告信息

向 Web 控制台输出一条警告信息。

语法

console.warn(obj1 [, obj2, ..., objN]);

console.warn(msg [, subst1, ..., substN]);

console.warn({ warn: "warn" });
console.warn("warn");

控制台输出如图
console_第3张图片
console-warn.png

Console.error() 打印一条错误信息

向 Web 控制台输出一条错误消息。

语法

console.error({ error: "error" });
console.error("error");
console.exception({ exception: "exception" });
console.exception("exception");

控制台输出如图
console_第4张图片
console-error.png

注意: console.exception() 是 console.error() 的别名;它们功能相同。chrome 未实现


Console.dir() 打印一条以三角形符号开头的语句,可以点击三角展开查看对象的属性

在控制台中显示指定 JavaScript 对象的属性,并通过类似文件树样式的交互列表显示

语法

console.dir(object); 打印出该对象的所有属性和属性值

console.dir({ dir: "dir" });

控制台输出如图
console_第5张图片
console-dir.png

Console.debug() 在控制台打印一条 "debug" 级别的消息

输出“调试”级别的消息且仅仅控制台配置为显示调试输出时才显示该消息

语法

console.debug(对象 1 [, 对象 2, ..., 对象 N]);
console.debug(消息[, 字符串 1, ..., 字符串 N]);

console.debug({ debug: "debug" });
console.debug("debug");

控制台输出如图
console_第6张图片
console-debug.png

若控制台不显示, 可以参照上图, 勾选 Verbose 试试


Console.assert() 判断第一个参数是否为真,false 的话抛出异常并且在控制台输出相应信息

如果断言为 false,则将一个错误消息写入控制台。如果断言是 true,没有任何反应

语法

console.assert(assertion, obj1 [, obj2, ..., objN]);
console.assert(assertion, msg [, subst1, ..., substN]);

console.assert(1 === 3, "not true");
console.assert(1 === 3, { assert: "assert", message: "not true" });

控制台输出如图
console_第7张图片
console-assert.png

Console.count() 以参数为标识记录调用的次数,调用时在控制台打印标识以及调用次数

输出 count() 被调用的次数。此函数接受一个可选参数 label

语法

console.count()
console.count(label)

console.count();
console.count("count");
console.count("count");
console.count();
console.count();
console.count("count");
console.count();

控制台输出如图
console_第8张图片
console-count.png

Console.countReset() 重置指定标签的计数器值

重置 console.count()的计数

语法

console.countReset([label]);
label 一个字符串, 若传入此参数 countReset() 重置此 label 的 count 为 0。若忽略此参数 countReset() 重置 count()默认的 default 字段的 count 为 0

console.count();
console.count("count");
console.count("count");
console.count();
console.count();
console.count("count");
console.count();
console.countReset();
console.count();

控制台输出如图
console_第9张图片
console-countReset.png

Console.clear() 清空控制台,并输出 Console was cleared

控制台显示的内容将会被一些信息替换,比如‘Console was cleared’这样的信息

需要的注意的一点是在 Google Chrome 浏览器中,如果用户在设置中勾选了“Preserve log”选项,console.clear()将不会起作用

语法

console.clear();

console.count();
console.count("count");
console.count("count");
console.count();
console.count();
console.count("count");
console.count();
console.countReset();
console.count();
console.clear();

控制台输出如图
console_第10张图片
console-clear.png

Console.dirxml() 打印 XML/HTML 元素表示的指定对象,否则显示 JavaScript 对象视图

显示一个明确的 XML/HTML 元素的包括所有后代元素的交互树。 如果无法作为一个 element 被显示,那么会以 JavaScript 对象的形式作为替代。 它的输出是一个继承的扩展的节点列表,可以让你看到子节点的内容

语法

console.dirxml(object);

console.dirxml("xxx");
console.dirxml(false);
console.dirxml({ dirxml: "dirxml", two: "two" });

控制台输出如图
console_第11张图片
console-dirxml.png

Console.group() 创建一个新的内联 group, 后续所有打印内容将会以子层级的形式展示。调用 groupEnd()来闭合组

在 Web 控制台上创建一个新的分组.随后输出到控制台上的内容都会被添加一个缩进,表示该内容属于当前分组,直到调用 console.groupEnd()之后,当前分组结束.

语法

console.group();

console.group();
console.log("xxx");
console.log("xxx");
console.log("xxx");
console.log("xxx");
console.group();
console.log("yyyy");
console.log("yyyy");
console.log("yyyy");

控制台输出如图
console_第12张图片
console-group.png

Console.groupCollapsed() 创建一个新的内联 group。使用方法和 group() 相同,不同的是,groupCollapsed() 方法打印出来的内容默认是折叠的

在 Web 控制台上创建一个新的分组.随后输出到控制台上的内容都会被添加一个缩进,表示该内容属于当前分组,直到调用 console.groupEnd() 之后,当前分组结束.和 console.group()方法的不同点是,新建的分组默认是折叠的.用户必须点击一个按钮才能将折叠的内容打开.

语法

console.groupCollapsed();

console.groupCollapsed();
console.log("xxx");
console.log("xxx");
console.log("xxx");
console.log("xxx");
console.groupCollapsed();
console.log("yyyy");
console.log("yyyy");
console.log("yyyy");

控制台输出如图
console_第13张图片
console-groupCollapsed.png

Console.groupEnd() 闭合当前内联 group

在 Web 控制台中退出一格缩进(结束分组). 请参阅 console 中的 Using groups in the console 来获取它的用法和示例.

语法

console.groupEnd();

console.group();
console.log("xxx");
console.group();
console.log("xxx");
console.group();
console.log("xxx");
console.log("xxx");
console.groupEnd();
console.group();
console.log("yyyy");
console.log("yyyy");
console.log("yyyy");

控制台输出如图
console_第14张图片
console-groupEnd.png

Console.table() 将列表型的数据打印成表格

将数据以表格的形式显示。

这个方法需要一个必须参数 data,data 必须是一个数组或者是一个对象;还可以使用一个可选参数 columns。

它会把数据 data 以表格的形式打印出来。数组中的每一个元素(或对象中可枚举的属性)将会以行的形式显示在表格中。

表格的第一列是 index。如果数据 data 是一个数组,那么这一列的单元格的值就是数组的索引。 如果数据是一个对象,那么它们的值就是各对象的属性名称。 注意(在 FireFox 中)console.table 被限制为只显示 1000 行

语法

console.table(data [, columns]);

参数

data
要显示的数据。必须是数组或对象。
columns
一个包含列的名称的数组。

let data = ["one", "two", "tree", "four"];
console.table(data);
let data2 = [{ one: "one", two: "two" }, { two: "two" }, { tree: "tree" }];
console.table(data2);
let data3 = { one: data, two: data2 };
console.table(data3);
let data4 = { one: "one", two: "two", tree: "tree" };
console.table(data4);

控制台输出如图
console_第15张图片
console-table.png

皮了一下, 这个函数太好玩了, 哈哈哈 O(∩_∩)O 哈哈~
还有更好玩的组合你们随意, 我就不皮了, 点到为止


Console.time() 启动一个以入参作为特定名称的计时器,在显示页面中可同时运行的计时器上限为 10,000

你可以启动一个计时器来跟踪某一个操作的占用时长。每一个计时器必须拥有唯一的名字,页面中最多能同时运行 10,000 个计时器。当以此计时器名字为参数调用 console.timeEnd() 时,浏览器将以毫秒为单位,输出对应计时器所经过的时间。

语法

console.time(timerName);

console.time("tabletime");
console.log("start");
let sum = 0;
for (let i = 0; i < 10000; i++) {
  sum += i;
}
console.log("end");
console.timeEnd("tabletime");

控制台输出如图
console_第16张图片
console-time.png

Console.timeEnd() 结束特定的 计时器 并以豪秒打印其从开始到结束所用的时间

停止一个通过 console.time() 启动的计时器

语法

console.timeEnd(label);

console.time("tabletime");
console.log("start");
let sum = 0;
for (let i = 0; i < 10000; i++) {
  sum += i;
}
console.log("end");
console.timeEnd("tabletime");

控制台输出如图
console_第17张图片
console-time.png

Console.timeLog() 打印特定 计时器 所运行的时间

在控制台输出计时器的值,该计时器必须已经通过 console.time() 启动。

语法

console.timeLog(label);

label
计时器索引。

console.time("tabletime");
let sum = 0;
for (let i = 0; i < 10000; i++) {
  sum += i;
}
console.timeLog();
console.timeLog("tabletime");
console.timeEnd("tabletime");

console.time();
console.timeLog();
console.timeEnd();

console.timeLog("end");

控制台输出如图
console_第18张图片
console-timeLog.png

第一个 timeLog 由于没有 console.time() 启动, 所以警告 Timer 'default' does not exist;

第二个 timeLog 传入了有 console.time() 启动的 label 'tabletime', 所以正常运行

第三个 timeLog 有 console.time() 启动, 所以正常运行

第四个 timeLog 传入了 label, 但没有 对应的 console.time() 来启动, 所以警告 Timer 'default' is dose not exist


Console.trace() 输出一个 stack trace

在页面 console 文档中查看堆栈跟踪的详细介绍和示例

语法

console.trace(); 无参数

console.trace();

控制台输出如图
console_第19张图片
console-trace.png

目前整理的常用的 console 用法就这些, 本文参考 MDN
有兴趣的可以移步 MDN, 更多有趣的姿势等你来解锁, bye !

你可能感兴趣的:(console)