视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
Javascript调试命令不止Console.log()
2020-11-27 20:04:26 责编:小采
文档
 Console对象可以在任何全局对象中访问,如 Window,WorkerGlobalScope 以及通过属性工作台提供的特殊定义。它被浏览器定义为 Window.Console,也可被简单的 Console 调用。Console 对象提供对浏览器控制台的接入(如:Firefox 的 Web Console)。不同浏览器上它的工作方式是不一样的,但这里会介绍一些大都会提供的接口特性。

最常用的方法就是Console.log(),就是在控制台输出内容。刚开始学前端的时候看到大家都是用的Console.log(),几乎没有见过Console的其他用法,难道Console真的没有别的用法了?查了一下后发现Console还是非常强大的,至于为什么很少看到有人用可能是因为用过都删掉了吧。在此记录一下Console的其他用法。

注意:因为Console 对象提供对浏览器控制台的接入 所以在不同浏览器中的支持及表现形式可能不太一样,但是调试内容只有我们开发者会看,所以保证开发环境能用这些方法就可以了,下面演示全部都为Chrome上面的效果。

分类输出

不同类别信息的输出

console.log('文字信息');
console.info('提示信息');
console.warn('警告信息');
console.error('错误信息');

分组输出

使用Console.group()Console.groupEnd()包裹分组内容。

还可以使用Console.groupCollapsed()来代替Console.group()生成折叠的分组。

console.group('第一个组');
 console.log("1-1");
 console.log("1-2");
 console.log("1-3");
console.groupEnd();

console.group('第二个组');
 console.log("2-1");
 console.log("2-2");
 console.log("2-3");
console.groupEnd();

Console.group()还可以嵌套使用

console.group('第一个组');
 console.group("1-1");
 console.group("1-1-1");
 console.log('内容');
 console.groupEnd();
 console.groupEnd();
 console.group("1-2");
 console.log('内容');
 console.log('内容');
 console.log('内容');
 console.groupEnd();
console.groupEnd();

console.groupCollapsed('第二个组');
 console.group("2-1");
 console.groupEnd();
 console.group("2-2");
 console.groupEnd();
console.groupEnd();

表格输出

使用console.table()可以将传入的对象,或数组以表格形式输出。适合排列整齐的元素

var Obj = {
 Obj1: {
 a: "aaa",
 b: "bbb",
 c: "ccc"
 },
 Obj2: {
 a: "aaa",
 b: "bbb",
 c: "ccc"
 },
 Obj3: {
 a: "aaa",
 b: "bbb",
 c: "ccc"
 },
 Obj4: {
 a: "aaa",
 b: "bbb",
 c: "ccc"
 }
}

console.table(Obj);

var Arr = [
 ["aa","bb","cc"],
 ["dd","ee","ff"],
 ["gg","hh","ii"],
]

console.table(Arr);

查看对象

使用Console.dir()显示一个对象的所有属性和方法
在Chrome中Console.dir()Console.log()效果相同

var CodeDeer = {
 nema: 'CodeDeer',
 blog: 'www.xluos.com',
 
}
console.log("console.dir(CodeDeer)");
console.dir(CodeDeer);

console.log("console.log(CodeDeer)");
console.log(CodeDeer);

查看节点

使用Console.dirxml()显示一个对象的所有属性和方法
在Chrome中Console.dirxml()Console.log()效果相同

百度首页logo的节点信息

条件输出

利用console.assert(),可以进行条件输出。

  • 当第一个参数或返回值为真时,不输出内容

  • 当第一个参数或返回值为假时,输出后面的内容并抛出异常

  • console.assert(true, "你永远看不见我");
    console.assert((function() { return true;})(), "你永远看不见我");
    
    console.assert(false, "你看得见我");
    console.assert((function() { return false;})(), "你看得见我");

    计次输出

    使用Console.count()输出内容和被调用的次数

    (function () {
     for(var i = 0; i < 3; i++){
     console.count("运行次数:");
     }
    })()

    追踪调用堆栈

    使用Console.trace()来追踪函数被调用的过程,在复杂项目时调用过程非常多,用这个命令来帮你缕清。

    function add(a, b) {
     console.trace("Add function");
     return a + b;
    }
    
    function add3(a, b) {
     return add2(a, b);
    }
    
    function add2(a, b) {
     return add1(a, b);
    }
    
    function add1(a, b) {
     return add(a, b);
    }
    
    var x = add3(1, 1);

    计时功能

    使用Console.time()Console.timeEnd()包裹需要计时的代码片段,输出运行这段代码的事件。

  • Console.time()中的参数作为计时器的标识,具有唯一性。

  • Console.timeEnd()中的参数来结束此标识的计时器,并以毫秒为单位返回运行时间。

  • 最多同时运行10000个计时器。

  • console.time("Chrome中循环1000次的时间");
    for(var i = 0; i < 1000; i++)
    {
    
    }
    console.timeEnd("Chrome中循环1000次的时间");

    性能分析

    使用Console.profile()Console.profile()进行性能分析,查看代码各部分运行消耗的时间,但是我在Chrome自带的调试工具中并没有找到在哪里查看这两个方法生成的分析报告。应该需要其他的调试工具。

    有趣的Console.log()

    最后再来介绍一下强大的Console.log(),这个方法有很多的用法(其他输出方法的用法,如error()等,可以参照log()使用)。

    一、提示输出

    可以再输出的对象、变量前加上提示信息,增加辨识度

    var ans = 12345;
    console.log("这是临时变量ans的值:",ans);

    二、格式化输出

    占位符含义
    %s字符串输出
    %d or %i整数输出
    %f浮点数输出
    %o打印javascript对象,可以是整数、字符串以及JSON数据

    样例:

    var arr = ["小明", "小红"];
    
    console.log("欢迎%s和%s两位新同学",arr[0],arr[1]);
    
    console.log("圆周率整数部分:%d,带上小数是:%f",3.1415,3.1415);

    三、自定义样式

    使用%c为打印内容定义样式,再输出信息前加上%c,后面写上标准的css样式,就可以为输出的信息添加样式了

    console.log("%cMy stylish message", "color: red; font-style: italic");
    
    console.log("%c3D Text", " text-shadow: 0 1px 0 #ccc,0 2px 0 #c9c9c9,0 3px 0 #bbb,0 4px 0 #b9b9b9,0 5px 0 #aaa,0 6px 1px rgba(0,0,0,.1),0 0 5px rgba(0,0,0,.1),0 1px 3px rgba(0,0,0,.3),0 3px 5px rgba(0,0,0,.2),0 5px 10px rgba(0,0,0,.25),0 10px 10px rgba(0,0,0,.2),0 20px 20px rgba(0,0,0,.15);font-size:5em");
    
    console.log('%cRainbow Text ', 'background-image:-webkit-gradient( linear, left top, right top, color-stop(0, #f22), color-stop(0.15, #f2f), color-stop(0.3, #22f), color-stop(0.45, #2ff), color-stop(0.6, #2f2),color-stop(0.75, #2f2), color-stop(0.9, #ff2), color-stop(1, #f22) );color:transparent;-webkit-background-clip: text;font-size:5em;');
    
    console.log('%cMy name is classicemi.', 'color: #fff; background: #f40; font-size: 24px;');

    总结

    Console的用法很多,有些再调试过程中非常实用,可以节省很多时间。当然我知道debug还是用断点调试的方法比较好,但是小问题用“printf大法”也是很好用的(滑稽脸)。

    下载本文
    显示全文
    专题