Chrome Devtools 高级调试指南(新)

前言

本文暂未涉及Performance面板的内容。 后续会单独出一篇,如下是目录:css

  1. 经常使用命令和调试
  2. 黑盒脚本:Blackbox Script
  3. 控制台内置指令
  4. 远程调试WebView

1. Chrome Devtools 的用处

  • 前端开发:开发预览、远程调试、性能调优、bug跟踪、断点调试等
  • 后端开发:网络抓包、开发调试Response
  • 测试:服务端API数据是否正确、审查页面元素样式及布局、页面加载性能分析、自动化测试
  • 其余:安装扩展插件,如AdBlock、Gliffy、Axure

2. 菜单面板拆解

  • Elements - 页面dom元素
  • Console - 控制台
  • Sources - 页面静态资源
  • Network - 网络
  • Performance - 设备加载性能分析
  • Application - 应用信息,PWA/Storage/Cache/Frames
  • Security - 安全分析
  • Audits - 审计,自动化测试工具

3. 经常使用命令和调试

1. 呼出快捷指令面板:cmd + shift + p

Devtools打开的状况下,键入cmd + shift + p将其激活,而后开始在栏中键入要查找的命令或输入"?"号以查看全部可用命令。前端

  • ...: 打开文件
  • :: 前往文件
  • @:前往标识符(函数,类名等)
  • !: 运行脚本文件
  • >: 打开某菜单功能

1.性能监视器:> performance monitor

将显示性能监视器以及相关信息,例如CPU,JS堆大小和DOM节点。

2.FPS实时监控性能:> FPS选择第一项

3.截图单个元素:> screen 选择Capture node screenhot

2. DOM断点调试

当你要调试特定元素的DOM中的更改时,可使用此选项。这些是DOM更改断点的类型: vue

  • Subtree modifications: 子节点删除或添加时
  • Attributes modifications: 属性修改时
  • Node Removal: 节点删除时

如上图:监听form标签,在input框得到焦点时,触发断点调试node

3. 黑盒脚本:Blackbox Script

剔除多余脚本断点。jquery

例如第三方(Javascript框架和库,广告等的堆栈跟踪)。git

为避免这种状况并集中精力处理核心代码,在Sources或网络选项卡中打开文件,右键单击并选择Blackbox Script github

4. 事件监听器:Event Listener Breakpoints

  1. 点击Sources面板
  2. 展开Event Listener Breakpoints
  3. 选择监听事件类别,触发事件启用断点

如上图: 监听了键盘输入事件,就会跳到断点处。

5. 本地覆盖:local overrides

使用咱们本身的本地资源覆盖网页所使用的资源。web

相似的,使用DevTools的工做区设置持久化,将本地的文件夹映射到网络,在chrome开发者功能里面对css 样式的修改,都会直接改动本地文件,页面从新加载,使用的资源也是本地资源,达到持久化的效果。面试

  • 建立一个文件夹以在本地添加替代内容;
  • 打开Sources > Overrides > Enable local Overrides,选择本地文件夹
  • 打开Elements,编辑样式,自动生成本地文件。
  • 返回Sources,检查文件,编辑更改。

该项能够自动修改除XHR异步请求的资源,下载的文件若未格式化,能够点左下角。chrome

6. 扩展:local overrides模拟Mock数据

来自:chrome 开发者工具 - local overrides

对于返回json 数据的接口,能够利用该功能,简单模拟返回数据。

好比:

  • api 为: http://www.xxx.com/api/v1/list

  • 在根目录下,新建文件www.xxx.com/api/v1/listlist 文件中的内容,与正常接口返回格式相同。

对象或者数组类型,从而覆盖掉原接口请求。

4. 控制台内置指令

能够执行常见任务的功能,例如选择DOM元素,触发事件,监视事件,在DOM中添加和删除元素等。

这像是Chrome自身实现的jquery增强版。

1. $(selector, [startNode]):单选择器

document.querySelector的简写 语法:

$('a').href;
$('[test-id="logo-img"]').src;
$('#movie_player').click();
复制代码

控制台还会预先查询对应的标签,十分贴心。 还能够触发事件,如暂停播放:

此函数还支持第二个参数startNode,该参数指定从中搜索元素的“元素”或Node。此参数的默认值为document

2. $$(选择器,[startNode]):全选择器

document.querySelectorAll的简写,返回一个数组标签元素 语法:

$$('.button')
复制代码

能够用过循环实现切换全选
或者打印属性

此函数还支持第二个参数startNode,该参数指定从中搜索元素的“元素”或Node。此参数的默认值为document 用法:

var images = $$('img', document.querySelector('.devsite-header-background'));
   for (each in images) {
       console.log(images[each].src);
}
复制代码

3. $x(path, [startNode])xpath选择器

$x(path)返回与给定xpath表达式匹配的DOM元素数组。

例如,如下代码返回<p>页面上的全部元素:

$x("//p")
复制代码

如下代码返回 <p>包含 <a>元素的全部元素:

$x("//p[a]")
复制代码

xpath多用于爬虫抓取,前端的同窗可能不熟悉。

4. getEventListeners(object):获取指定对象的绑定事件

getEventListeners(object)返回在指定对象上注册的事件侦听器。返回值是一个对象,其中包含每一个已注册事件类型(例如,clickkeydown)的数组。每一个数组的成员是描述为每种类型注册的侦听器的对象。 用法:

getEventListeners(document);
复制代码

相对于到监听面板里查事件,这个 API便捷多了。

5. 花式console

除了不一样等级的 warnerror打印外
还有其它很是实用的打印。

1. 变量打印:%s%o%d、和%c

const text = "文本1"
console.log(`打印${text}`)
复制代码

除了标准的ES6语法,实际上还支持四种字符串输出。 分别是:

console.log("打印 %s", text)
复制代码
  • %s:字符串
  • %o:对象
  • %d:数字或小数

还有比较特殊的%c,可用于改写输出样式。

console.log('%c 文本1', 'font-size:50px; background: ; text-shadow: 10px 10px 10px blue')
复制代码

固然,你也能够结合其它一块儿用(注意占位的顺序)。

const text = "文本1"
console.log('%c %s', 'font-size:50px; background: ; text-shadow: 10px 10px 10px blue', text)
复制代码

你还能够这么玩:

console.log('%c Auth ', 
            'color: white; background-color: #2274A5', 
            'Login page rendered');
console.log('%c GraphQL ', 
            'color: white; background-color: #95B46A', 
            'Get user details');
console.log('%c Error ', 
            'color: white; background-color: #D33F49', 
            'Error getting user details');
复制代码

2. 打印对象的小技巧

当咱们须要打印多个对象时,常常一个个输出。且看不到对象名称,不利于阅读:

之前个人作法是这么打印:

console.log('hello', hello);
console.log('world', world);
复制代码

这显然有点笨拙繁琐。其实,输出也支持对象解构:

console.log({hello, world});
复制代码

3. 布尔断言打印:console.assert()

当你须要在特定条件判断时打印日志,这将很是有用。

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

语法

console.assert(assertion,obj)
复制代码

用法

const value = 1001
console.assert(value===1000,"value is not 1000")
复制代码

4. 给console编组:console.group()

当你须要将详细信息分组或嵌套在一块儿以便可以轻松阅读日志时,可使用此功能。

console.group('用户列表');
console.log('name: 张三');
console.log('job: 🐶前端');
// 内层
console.group('地址');
console.log('Street: 123 街');
console.log('City: 北京');
console.log('State: 在职');
console.groupEnd(); // 结束内层
console.groupEnd(); // 结束外层
复制代码

5. 测试执行效率:console.time()

没有Performance API 精准,但胜在使用简便。

let i = 0;
console.time("While loop");
while (i < 1000000) {
  i++;
}
console.timeEnd("While loop");
console.time("For loop");
for (i = 0; i < 1000000; i++) {
  // For Loop
}
console.timeEnd("For loop");
复制代码

6. 输出表格:console.table()

这个适用于打印数组对象。。。

let languages = [
    { name: "JavaScript", fileExtension: ".js" },
    { name: "TypeScript", fileExtension: ".ts" },
    { name: "CoffeeScript", fileExtension: ".coffee" }
];
console.table(languages);
复制代码

7. 打印DOM对象节点:console.dir()

打印出该对象的全部属性和属性值. console.dir()console.log()的做用区别并不明显。若用于打印字符串,则输出一摸同样。

console.log("Why,hello!");
console.dir("Why,hello!");
复制代码

在输出对象时也仅是显示不一样( log识别为字符串输出, dir直接打印对象。)。

惟一显著区别在于打印dom对象上:

console.log(document)
console.dir(document)
复制代码

一个打印出纯标签,另外一个则是输出 DOM树对象。

6. 远程调试WebView

使用Chrome开发者工具在原生Android应用中调试WebView

  1. 配置WebViews进行调试。

    WebView类上调用静态方法setWebContentsDebuggingEnabled

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT) {
        WebView.setWebContentsDebuggingEnabled(true);
    }
    复制代码
  2. 手机打开usb调试,插上电脑。

  3. Chrome地址栏输入:Chrome://inspect

正常的话在 App中打开 WebView时, chrome中会监听到并显示你的页面。 4. 点击页面下的 inspect,就能够实时看到手机上 WebView页面的显示状态了。(第一次使用可能会白屏,这是由于须要去 https://chrome-devtools-frontend.appspot.com那边下载文件)

除了inspect标签,还有 Focus tab:

  • 它会自动触发Android设备上的相同操做

其余应用里的WebView也能够,例如这是某个应用里的游戏,用的也是网页:

7.调试Node.js

具体能够查看阿里云社区的这篇:

Node.js应用程序故障排除手册-正确启用Chrome DevTools

Ps: 属于个人知识盲区,就不搬运造次了。

参考资料

  1. Practical Chrome Devtools — Common commands & Debugging
  2. Mobile web specialist — Remote Debugging
  3. Console Utilities API Reference
  4. Console API Reference

❤️ 看完三件事

若是你以为这篇内容对你挺有启发,我想邀请你帮我三个小忙:

  1. 点赞,让更多的人也能看到这篇内容(收藏不点赞,都是耍流氓 -_-)
  2. 关注公众号「前端劝退师」,不按期分享原创知识。
  3. 也看看其它文章

也能够来个人GitHub博客里拿全部文章的源文件:

前端劝退指南github.com/roger-hiro/…

相关文章
相关标签/搜索