一、前言

  可能很多前端er会习惯用 alert() 方法来进行调试,但我相信更多的人会使用 console.log(),因为它不用像 alert() 那样会有字符长度限制,也不会中止程序的进程,而且还可以同时输出多条信息,当然各有各的好处。之前,我还一直以为只有 console.log() 这一种方法可以在控制台输出信息,直到在早读君(前端早读课)推出的一篇《JavaScript中console 的用法》才发现原来,console 还有那么多方法。所以又查了一些相关的资料,以便全面具体的学习这些方法。好啦,废话不多说,咱们正文走起。

二、正文

  在 Chrome 浏览器控制台输入console,会输出 console对象的全部方法。

1、输出信息:console.log() 、 console.debug() 、 console.error() 、 console. warn() 、 console.info()  

  console.log() ---- 输出普通信息

  用法:console.debug(object [, object, ...])

  

  输出结果:

  

  细心的小伙伴会发现,当使用表达式输出字符串时,需要手动添加空格,而以逗号为间隔,输出多个变量时,console会在多个变量之间自动添加空格,使用时要注意哦!

  除此之外,console.log() 还可以像 C 语言一样,使用 printf 风格的占位符,但只支持字符(%s)、整数(%d 或 %i)、浮点数(%f)和对象(%o)这四种类型。

  console.debug() ---- 输出调试信息

  console.error() ---- 输出错误信息

  console. warn() ---- 输出警告信息

  console.info() ---- 输出提示性信息

  这四钟输出形式的使用方法和 console.log() 是一样的,只是表现形式不同。

  输出结果:

  

2、以分组形式输出打印结果: console.group() 、console.groupEnd() 、 console.groupCollapsed()

  console.group() 、console.groupCollapsed() ---- 分组开始

  console.groupEnd() ---- 分组结束

  用法:console.group(object[, object, ...])

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

     console.groupEnd()

  使用相同的 label 进行分组输出,若将代码中 console.group() 换成 console.groupCollapsed(),则默认按组折叠输出。

  

  输出结果:

  

3、统计代码运行时间:console.time() 、 console.timeEnd()

  console.time() ---- 开始计时

  console.timeEnd() ---- 结束计时

  用法:console.time(label)

     console.timeEnd(label)

  主要用于了解一段代码执行所需时间,具体运行时间也不完全取决于代码,和用户所使用的浏览器也是有一定关系的。

  

  Chrome 运行结果:

  

  Firefox 运行结果:

  

4、统计代码运行次数:console.count()

  用法:console.count(label)

   console.count() 被调用时,可以统计出同一标签被调用的次数。

  

  运行结果:

  

5、判断某个变量或者表达式的真假:console.assert()

  用法:console.assert(expression, object)

  当 expression 判定失败时,会输出 object

  当 expression 判定成功时,不输出任何内容

  如果不输入 object 的话,浏览器也不会报错,只是会显示出 console.assert() , 如下图所示。

  

  运行结果:

  

6、输出对象:console.dir()

  用法:console.dir(object)

  只是简单的输出某个对象时,console.dir() 在 Chrome 中的输出效果和 console.log() 类似,手动展开后,完全一样。

  

  输出结果:

  

  展开后:

  

  我们再来看下,Firefox中的显示结果:

  

  看起来结构更加清晰,但基本和 Chrome 是一样。你以为这就是 console.dir() 的全部用途啦?错,当 console.dir() 中的参数为 HTML 节点时, console.log() 会以HTML文档的形式输出,而console.dir() 则会 Json 的结构输出,便于查看各个方法及属性值。

  

  输出结果:

  

  再来看下 FireFox中的输出结果:

  

  基本是一样的。

7、显示某个节点所包换的 html/xml 代码:console.dirxml()

  用法:console.dirxml(object)

  

  

  输出结果:

  

  

  

参考文档:

JavaScript 中 console 的用法 ( https://zhuanlan.zhihu.com/p/23080626 )

Chrome 控制台console的用法 (http://www.open-open.com/lib/view/open1421131601390.html)

js调试工具Console命令详解 (http://www.jb51.net/article/56504.htm)

Google API:

https://developers.google.com/web/tools/chrome-devtools/console/console-reference?utm_source=dcc&utm_medium=redirect&utm_campaign=2016q3

调试必备---console的更多相关文章

  1. 利用Nginx轻松实现Ajax的跨域请求(前后端分离开发调试必备神技)

    利用Nginx轻松实现浏览器中Ajax的跨域请求(前后端分离开发调试必备神技) 前言 为什么会出现跨域? 造成跨域问题的原因是因为浏览器受到同源策略的限制,也就是说js只能访问和操作自己域下的资源,不 ...

  2. JS调试必备的5个debug技巧_javascript技巧

    JS调试必备的debug调试javascript技巧 1. debugger; 我以前也说过,你可以在JavaScript代码中加入一句debugger;来手工造成一个断点效果.需要带有条件的断点吗? ...

  3. Chrome浏览器调试,console简述

    作为一个前端开发者,不可避免的需要进行各种各样的调试. 在谷歌浏览器出来以前,火狐的firebug是特别有名的一款调试工具,不过自从谷歌浏览器诞生以来,其自带的开发者工具足以媲美firebug,某种程 ...

  4. JS调试必备的5个debug技巧

    我一直使用printf调试程序,一般来说都是比较顺利,但有时候,你会发现需要更好的方法.下面几个JavaScript技巧相信你一定会觉得十分有用   1. debugger; 我以前也说过,你可以在J ...

  5. !学习笔记:前端测试 、前端调试、console 等

    http://www.cnblogs.com/rubekid/p/4851988.html 你真的了解 console 吗 2014 http://www.codeceo.com/article/ja ...

  6. Javascript调试利器console的使用

    一.Console API Console.assert() 判断第一个参数是否为真,false的话抛出异常并且在console输出相应信息. Console.count() 以参数为标识记录调用的次 ...

  7. 新一代调试王者Console

    随着JS在Web前端中能做的事情越来越多,责任越来越大,而地位也越来越重要.传统的alert调试方式已经渐渐不能满足前端开发的种种场景.而且alert调试方式弹出的调试信息,那个窗口着实不太美观,而且 ...

  8. JavaScript调试中Console命令

    JS调试中,用console.log 感觉比 alert 好用,不用弹出窗口,还要关闭.除了console.log()其他命令没怎么用过,先在这里记一下,用到时在看看 一.显示信息的命令 consol ...

  9. javascript 调试 使用console.table()

    或许你已经习惯了console.log()来调试js,非常使用,但是今天微博看到console.table()调试javascript,和console.log()类似,主要区别在于: 主要用来输出对 ...

随机推荐

  1. Oracle数据库基础知识1

    DDL语句 1.表的创建 CREATE TABLE table_name(); 例如: CREATE TABLE USER_E( id NUMBER (5), name VARCHAR(20), ge ...

  2. throw exception

    Throw new CustomerException('Customer message'); // App\Exceptions\Handler.php public function rende ...

  3. UITextField-修改占位文字和光标的颜色,大小

    一.设置占位文字的颜色 方法一:利用富文本 /** 手机号输入框 */ @property (weak, nonatomic) IBOutlet UITextField *phoneTextField ...

  4. cloudera learning5:Hadoop集群高级配置

    HDFS-NameNode Tuning: dfs.namenode.handler.count: NameNode可开启的thread number,thread为从NameNode到DataNod ...

  5. itellij idea导入web项目并部署到tomcat

    概述 主要分为项目配置和tomcat配置两大步骤. 一.项目配置 打开idea,选择导入项 选择将要打开的项目路径后,继续选择项目的原本类型(后续引导设置会根据原本的项目类型更新成idea的项目),此 ...

  6. [CC]平面拟合

    常见的平面拟合方法一般是最小二乘法.当误差服从正态分布时,最小二乘方法的拟合效果还是很好的,可以转化成PCA问题. 当观测值的误差大于2倍中误差时,认为误差较大.采用最小二乘拟合时精度降低,不够稳健. ...

  7. lua协程一则报错解决“attempt to yield across metamethod/C-call boundary”

    问题 attempt to yield across metamethod/C-call boundary 需求跟如下帖子中描述一致: http://bbs.chinaunix.net/forum.p ...

  8. 化繁为简,最简易的SqlDataSource配合Cache使用~

    最近一个小项目用了比较方便傻瓜的DevExpress控件,实践中DevExpress的控件确实很方便. 在用ASPxGridView控件的时候,为了偷懒结合了SqlDataSource使用,但一直在大 ...

  9. PAT复杂度_最大子列和问题、最大子列和变种

    01-复杂度1. 最大子列和问题 给定K个整数组成的序列{ N1, N2, ..., NK },“连续子列”被定义为{ Ni, Ni+1, ..., Nj },其中 1 <= i <= j ...

  10. 第十二章Fundamental Data Types 基本数据类型

    目录: 12.1 数值概论 12.2整数 12.3浮点数 12.4 字符和字符串 12.5布尔变量 12.6枚举类型 12.7具名常量 12.8数组 12.9创建你自己的类型 12.1   数值概论 ...