Console的用法,以及Debug技巧

一.背景介绍

什么是console?

Chrome 中 Console 是用于显示 JS和 DOM 对象信息的单独窗口。并且向 JS 中注入1个 console 对象,使用该对象 可以输出信息到 Console 窗口中。在具备调试功能的浏览器上,window 对象中会注册一个名为 console 的成员变量,指代调试工具中的控制台,console 有很多方法,比如我们最常用的log()

二.知识剖析

常用console方法

1. console.log( )

普通输出方法,参数可以为任何对象。

            
        常量            console.log("常量");
        变量            console.log(name);
        表达式          console.log("名字:" + name);
        方法            console.log(document.getElementsByTagName("code"));
            
        

2. console.table()

可将传入的对象,或数组以表格形式输出,相比传统树形输出,这种输出方案更适合内部元素排列整齐的对象或数组,不然可能会出现很多的 undefined。

                
                        var obj = {
                            fun: {
                                name: 'foo',
                                age: '18'
                          },
                            bar: {
                                name: 'bar',
                                age: '19'
                          }
                        };

                        var arr = [
                            ['fun', '18'],
                            ['bar', '19']
                        ];

                        console.log(obj);
                        console.table(obj);

                        console.log(arr);
                        console.table(arr);

                
            

3.console.count([label])

输出执行到该行的次数例如:

                
                        (function() {
  for (var i = 0; i < 5; i++) {
    console.count('count');
  }
})();
// count: 1
// count: 2
// count: 3
// count: 4
// count: 5
                
            

4.console.time(name)

计时器,可以将成对的console.time()和console.timeEnd()之间代码的运行时间输出到控制台上,name参数可作为标签名。

            
console.time('计时器');
for (var i = 0; i < 1000; i++) {
  for (var j = 0; j < 1000; j++) {}
}
console.timeEnd('计时器');
            
        

5.console.profile([profileLabel])

这是个挺高大上的东西,可用于性能分析。在 JS 开发中,我们常常要评估段代码或是某个函数的性能。在函数中手动打印时间固然可以,但显得不够灵活而且有误差。借助控制台以及console.profile()方法我们可以很方便地监控运行性能。

例如下面这段代码:

                
                    function parent() {
  for (var i = 0; i < 10000; i++) {
    childA()
  }
}

function childA(j) {
  for (var i = 0; i < j; i++) {}
}

console.profile('性能分析');
parent();
console.profileEnd();
                
            

然后我们可以在 Profiles 面板下看到上述代码运行过程中的消耗时间。

页面加载过程的性能优化是前端开发的一个重要部分,使用控制台的 profiles 面板可以监控所有 JS 的运行情况使用方法就像录像机一样,控制台会把运行过程录制下来。如图,工具栏上有录制和停止按钮。

6. 其他方法

. 清除控制台 clear()

. 将对象及子元素以目录树列出来 console.dir()

. 条件打印(断言)console.assert()

3.常见问题

常用调试方法

4.解决方案

1. 断点调试

断点调试是最基础的一个调试方法,在调试的过程中查看变量和函数的变化状态,这使得不可见的程序运行过程变得可视化。 断点调试都在source选项卡中进行,所以放在下面一起来讨论。

2. sources 选项卡

a. 上图source选项代码序列上的蓝色标签即为断点的标识,断点也显示在Breakpoint选项中,可以在Breakpoint选项卡中勾掉暂时不用的断点,后面再使用的时候可以再勾选,这样就不用再代码中翻来翻去迷失方向了。 
b. 这几个小图标前两个和调试时页面的两个按钮相同, 分别是暂停/开始和单步;往右边两个向上向下的箭头意思是进入函数,和(执行完)跳出函数;后面的一个是忽略所有断点运行,这样被避免更改完之后,点掉所有断点执行一遍在挨个加断点的尴尬。 
c. watch窗口: 点击“+”添加一个想要监视的变量,在整个调试过程中,这个变量会一直显示在这里,就不用在函数之间苦苦寻找,然后再“hover”上去显示它的值,非常适合全局变量的监视。

5.编码实战

6.扩展思考

为什么不提倡用alert进行调试?

一方面,传统的alert调试方式已经渐渐不能满足前端开发的种种场景。而且alert调试方式弹出的调试信息,那个窗口着实不太美观,而且会遮挡部分页面内容,着实有些不太友好。

另一方面,alert的调试信息会中断代码,阻碍页面的继续渲染。这就意味着开发人员调试完成后,必须手动清除这些调试代码,实在有些麻烦。

另外,如果在循环中使用alert,光关闭弹出的窗口就够自己累的了,哈哈!

7.参考文献

参考一:你真的了解console吗

参考二:Chrome开发者工具不完全指南

参考三:Google Developers官网

参考三:CSDN中文IT网

8.更多讨论

大家在调试程序中有什么比较好的方法分享一下?

问题:

1:如何在控制台进行代码格式化?

在sources面板选中需要格式化的js文件,然后点击pretty print。


2:alert的更多缺点?

1).alert()是一种破坏性的方法,执行的时候弹出弹窗之后的代码就不会执行。

2).alert()还有一个缺点就是会将参数message转换为字符串。改变原信息格式。

3:console和打断点哪个更好用?

各有特长吧,如果你要验证一个特定的函数,是不是自己想要的效果,就用console,如果不确定页面的问题出在哪儿,就用断点调试。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值