Chrome调式技巧
1. 使用alert()调试
2. console
基本输出
console.log("打印字符串");
console.error("我是个错误");
console.info("我是是信息");
console.warn("我是是警告");
console.debug("我是是调试");
控制台显示结果:

console.clear(); //清空控制台
格式化输出
console.log("%s年",) //%s表示字符串
console.log("%d年%d月",,) //%d表示整数
console.log("%f",3.124443333) //%f表示小数
console.log("%o",console) //%o表示对象
console.log("%c自定义样式","font-size:30px;color:red;")
console.log("%c我是%c自定义样式","font-size:20px;color:green;","font-size:30px;color:red;")
控制台显示结果:

DOM输出
var ul=document.getElementsByTagName("ul");
//树形输出table节点,即<table>和它的innerHTML
console.dirxml(ul)
控制台显示结果:

对象输出:
var obj={
name:'song',
age:
}
console.dir(obj);
控制台显示结果:

多个对象的集合:使用console.table()输出
var obj = [
{name: 'Sunny', age: },
{name: 'Bob', age: },
{name: 'Lucy', age: },
]
console.log(obj);
console.table(obj)
控制台显示结果:

成组输出:
console.group("start");
console.log("sub1");
console.log("sub2");
console.log("sub3");
console.groupEnd("end");
控制台显示结果:

函数计数和跟踪:
//输出前n个斐波那契数列
function fib(n) {
if (n == ) return;
//放在函数里,每当这句代码运行,就会输出所在函数执行的次数
console.count("调用次数");
//显示函数调用轨迹(访问调用栈)
console.trace();
var a = arguments[] || ;
var b = arguments[] || ;
console.log("fib=" + a);
[a, b] = [b, a + b];
fib(--n, a, b);
}
fib();
控制台显示输出:

计时:
console.time();
fib(); //调用上面的斐波那契数列函数
console.timeEnd()
控制台输出结果:显示执行函数所使用的时间

性能分析:
console.profile()
fib(); //调用上面的斐波那契数列函数
console.profileEnd()
注:Chrome开发工具的Audits标签页也可以实现性能分析
debugger:断点调试

Pause/Resume script execution:暂停/恢复脚本执行(程序执行到下一断点停止)
Step over next function call:执行到下一步的函数调用(跳到下一行)
Step into next function call:进入当前函数
Step out of current function:跳出当前执行的函数
Deactive/Active all breakpoints 关闭/开启所有断点(不会取消断点)
Pause on exceptions:异常情况自动设置断点
Watch:Watch表达式
Call Stack:栈中变量的调用
Scope:当前作用域变量观察
Breakpoints:当前断点变量观察
XHR BreakPoints:面向ajax,专为异步而生的断点调试功能
DOM BreakPoints:主要包括下列DOM断点
当节点被移除时断点(Break on node removal)
当节点属性发生变化时断点(Break on attributes modifications)
当节点节点内部子节点变化时断点(Break on subtree modifications)
Global Listenters:全局事件监听
Event Lintener BreakPoints:事件监听器断点,列出了所有页面及脚本事件,包括鼠标、键盘、动画、定时器、XHR等
Chrome调试技巧总结
1. DOM元素的控制台标签
Chrome开发者工具和Firebug都提供了书签功能,用于显示你在元素标签页(Chrome)或HTML标签页(Firebug)中最后点击的DOM元素。
如果你依次选择了A元素、B元素、C元素,那么\$0表示C元素,\$1表示B元素,\$2表示A元素
2. 调试函数f,可以使用debug(f)语句
3. Source标签页左侧面板上有一个代码片段(Snippet)的子标签页,用于保存代码片段,帮你调试代码
4. 可以使用Chrome开发者工具中的Source标签页中的格式化按钮(Pretty Print Button)格式化压缩后的代码
5. 在Network面板,选择一个资源文件,右键Copy Response可以快速复制响应的内容
6. 利用媒体查询,这个主要在Device Mode调节不同的分辨率显示
7. 选择Elements,按Esc>Emulation>Sensors进行传感器模拟
8. 点击渐入效果样式图标(紫色图标),可以预览动画效果,并可对相应的贝塞曲线(cubic-bezier)进行调试动画效果
9. 在Source中按住Alt键并拖动鼠标进行多列内容选择
10. Elements面板右键执行DOM元素节点,选择Force Element State 或点击右侧Toggle Element State 图标可以触发伪类
11. Network面板中选择一张图片,在右侧图片上鼠标右键选择copy it as a Data URI,就可以获取图片的Data URL (base64编码)
12. 通过按住Ctrl键可以添加多个编辑光标,同时对多处进行编辑。按下Ctrl + U可以撤销编辑。
13. Elements面板右侧的Style编辑器中,点击颜色十六进制编码前的小色块,会弹出一个调色板。
14. 按下Alt键并且鼠标双击选择DOM元素前面的箭头,就会展开该DOM元素下的所有字节点元素.
15. 快捷键
快速定位到行:快捷键 Ctrl+O(Mac: CMD+O),输入:行号:列号 来进行定位
元素搜索:快捷键 Ctrl+F(Mac: CMD+F),试试在搜索栏输入ID选择符或者类选择符就可以定位到元素啦
Chrome调式技巧的更多相关文章
- chrome使用技巧
chrome使用技巧 chrome对于开发人员来说,绝对是一个神器.下面,介绍关于它的一些小技巧: 1.利用chrome快速定位source中的资源. 我之前一般如果查找每个文件,都是打开控制台,在s ...
- 转15个必须知道的chrome开发者技巧GIF
在Web开发者中,Google Chrome是使用最广泛的浏览器.六周一次的发布周期和一套强大的不断扩大开发功能,使其成为了web开发者必备的工具.你可能已经熟悉了它的部分功能,如使用console和 ...
- 15个必须知道的chrome开发者技巧(转)
15个必须知道的chrome开发者技巧 在Web开发者中,Google Chrome是使用最广泛的浏览器.六周一次的发布周期和一套强大的不断扩大开发功能,使其成为了web开发者必备的工具.你可能已经熟 ...
- Chrome 调试技巧
Chrome 调试技巧 1.alert 这个不用多说了,不言自明. 可参考:https://www.cnblogs.com/Michelle20180227/p/9110028.html 2.cons ...
- 前端开发神一样的工具chrome调试技巧
前端开发神一样的工具chrome调试技巧 文章来自 Colin-UED // 与您分享前端开发知识 主页 Javascript HTML CSS NodeJs User Experience FE ...
- chrome使用技巧(看了定不让你失望)
写在前面 之前有看过刘哇勇写的Chrome 控制台不完全指南,让我觉得瞬间对chrome的了解实在太浅了.对此特意了解了一番(也就是在他的博文上进行了一些总结和了解一些其它chrome使用方面的诀窍) ...
- Chrome 使用技巧
阅读目录 写在前面 快速切换文件 在源代码中搜索 在源代码中快速跳转到指定的行 使用多个插入符进行选择 设备模式 设备传感仿真 格式化凌乱的js源码 颜色选择器 改变颜色格式 强制改变元素状态(方便查 ...
- 15个必须知道的chrome开发者技巧
在Web开发者中,Google Chrome是使用最广泛的浏览器.六周一次的发布周期和一套强大的不断扩大开发功能,使其成为了web开发者必备的工具.你可能已经熟悉了它的部分功能,如使用console和 ...
- chrome使用技巧(转)good
阅读目录 写在前面 快速切换文件 在源代码中搜索 在源代码中快速跳转到指定的行 使用多个插入符进行选择 设备模式 设备传感仿真 格式化凌乱的js源码 颜色选择器 改变颜色格式 强制改变元素状态(方便查 ...
随机推荐
- [WIP]React 核心概念
创建: 2019/05/01 Hello World ReactDOM.render( <p>sample</p>, document.getElementById('ro ...
- server12装.NET 3.5
参考:https://support.microsoft.com/en-us/help/2734782/net-framework-3-5-installation-error-0x800f0906- ...
- Educational Codeforces Round 59 (Rated for Div. 2)
熬夜爆肝,智商急剧下降 坐标UTC+8晚上23:35开始 晚上脑袋转的慢,非常慢 T1上来先做还花了好几分钟 T2本来是有式子的我TM写数位DP写炸了然后才发现是有公式 T3英语不好,一开始题意没读懂 ...
- Docker部署MySql应用
1. MySQL部署 1.1拉取MySQL镜像 docker pull mysql 查看镜像 docker images 1.2创建MySQL容器 docker run -di --name piny ...
- ArcGIS-各类问题
arcgis 10.4破解方法*注意!Desktop,Engine,Server必须为同一版本 1.先安装License10.4 2.再安装Desktop10.4 3.再安装Engine10.4 4. ...
- 洛谷 P2141 珠心算测验
嗯... 先看一下这个题.... 题目描述 珠心算是一种通过在脑中模拟算盘变化来完成快速运算的一种计算技术.珠心算训练,既能够开发智力,又能够为日常生活带来很多便利,因而在很多学校得到普及. 某学校的 ...
- Exadata LVM snapshot备份失败
一台X4-2 的计算节点进行image升级,在正式升级之前利用LVM snapshot备份操作系统时备份失败,并且报大量IO错误,提示无法找到LVM snapshot的挂载点.检查文件系统状态: [r ...
- 【2014年百度之星资格赛1001】Energy Conversion
Problem Description 魔法师百小度也有遇到难题的时候—— 现在,百小度正在一个古老的石门面前,石门上有一段古老的魔法文字,读懂这种魔法文字需要耗费大量的能量和大量的脑力. 过了许久, ...
- CSS(十三).高度如何铺满全屏
该需求来源一次面试题. IE6不认识!important声明,IE7.IE8.Firefox.Chrome等浏览器认识:而在怪异模式中,IE6/7/8都不认识!important声明,这只是区别的一种 ...
- Nginx 基本 安装..
ubuntu 下 Nginx是高度自由化的Web服务器,它的功能是由许多模块来支持.如果使用了某个模块,这个模块使用了一些类似zlib或OpenSSL等的第三方库,那么就必须先安装这些软件.Ubunt ...