Chrome DevTools中的实用技巧

Chrome DevTools是开发者最好的“朋友”

随着Javascript框架的爆炸式增长,拥有在浏览器中实时处理代码的能力是尤为重要的,Chrome DevTools是内置在浏览器中的Web创作和调试工具,它们为开发人员提供了对其Web应用程序和浏览器的更深入访问。
您可以在DevTools中进行代码的调试,接口的测试,性能的检测等等强大的操作,极大程度的节省了开发者的时间。接下来,我将介绍几种在实际开发中会非常有用的技巧和窍门~

认识Chrome DevTools的控制面板

打开 DevTools的方式有很多中,适合自己的就是最好的,在这里我们介绍一下用快捷键的形式打开:

  • Mac: Cmd + Opt + I
  • Windowns: F12 or Ctrl + Shift + I
    image

从图片中我们可以看到DevTools中有很多不用类型的面板,包括Elements panel, Console panel, Sources panel等等,接下来我们重点介绍一下\color{red}{Sources panel,Elements panel,Console panel,Network panel}

Sources panel

  1. 如何快速查找以及定位文件的具体行数?
    我们可以使用 \color{red}{Cmd + P( Ctrl + p )} 进行快速查找文件,然后在找到的文件的命令菜单中输入\color{red}{:行数:列数,如(:13:14)}
image
  1. 如何对压缩的文件进行格式化?
    我们可以通过\color{red}{点击{}}来进行格式化压缩后的文件
image
  1. 如何在打断点的时候,注入代码?
    首先选择要注入代码的地方,\color{red}{右键输入Edit in breakPoint},接下来便可以进行相关代码的注入。这样就避免了我们要去项目中修改代码~
image
  1. 如何同时修改多行代码?
    我们可以使用\color{red}{Cmd + Click(Ctrl + Click)}来添加多个光标,并输入想要修改的内容。
image
  1. 如何选中hover之后出现的元素?
    • 首先打开sources 面板
    • 然后在页面上hover相关元素让其显示出tooltip的元素
    • 使用commond+\ 或者f8来暂停脚本的执行
    • 回到Elements面板,去检查tooltip的元素
image

Elements panel

  1. 如何快速展开一层层的Dom呢?
    我们只需要使用\color{red}{Alt/Option + Click }就可以打开嵌套多层的闭合状态下的Dom树。
image
  1. 如何在控制台中实现花式截图呢?
    • 我们可以选中需要被截图的元素节点。
    • 通过Cmd + Shift + P打开命令菜单
    • 在命令菜单中输入screenshot 选中你要的截图类型,即可实现相关的截图操作
image

截取特定节点对应上图命令是Screenshot Capture node screenshot,
通过 Screenshot Capture full size screenshot 命令可以截取全屏,不仅仅是可视区。

  1. 如何更改元素颜色的格式呢?
    我们只需使用 \color{red}{Shift + Click} 去点击元素的色块,就可以实现元素RGBA, HSL, and hexadecimal的格式更换。
image

Console panel

  1. 如何编辑页面上的文字呢?
    当我们希望整个页面的都可以被编辑的时候,我们只需要在console面板中输入\color{red}{document.body.contentEditable="true"}就可以实现对整个页面的编辑了。

  2. 如何进行数据的格式化复制呢?
    我们可以使用Devtools提供的工具函数 \color{red}{copy(obj)}来实现,即使给copy函数传入一个没有格式的 JSON,也会返回格式化的结果。执行完copy(obj),我们可以直接粘贴~

image
  1. 如何快速的获取对象的key和value呢?
    我们可以也是使用Devtools提供的工具函数 \color{red}{keys(obj)},\color{red}{values(obj)},具体事例如下:
image

Network panel

  1. 怎样重新发起xhr请求呢?
    以往我们都是通过刷新页面,点击按钮的等方式去触发xhr请求,现在我们可以使用google提供的\color{red}{Replay XHR} 的方式去发起一条新的请求。
    • 只需要选中要重新请求的链接
    • 右击选中Replay XHR即可。
image
  1. 怎样自定义网络限制的条件?
    当你想测试一下自己的程序在具体的网络条件下的表现,你就可以选择自定义网络的配置文件。
    • 在 Network panel中 点击online,选择其中的\color{red}{Add...}
    • 然后选择在新的弹窗中点击 \color{red}{Add custom profile...}
    • 输入自定义的相关条件即可


      image

总结

如您所见,Chrome DevTools具有众多功能,可帮助大家更好地开发,更快地调试并更有效地衡量网站或应用程序的性能,
上面提到的技巧只是众多可用功能中的几个。如果大家在实际开发中用到了有意思的DevTools功能,欢迎在下面的评论区中分享哦~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,192评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,858评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,517评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,148评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,162评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,905评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,537评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,439评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,956评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,083评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,218评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,899评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,565评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,093评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,201评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,539评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,215评论 2 358