”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 在 DevTools 中覆盖和模拟网络响应

在 DevTools 中覆盖和模拟网络响应

发布于2024-11-04
浏览:662

在诊断生产环境中的问题时,通常会面临很多风险。有缺陷的 API 调用、拖累性能的第三方脚本或数据管道中的无意错误都可能很快造成重大问题。值得庆幸的是,借助 Chrome DevTools,您可以在发布任何更改之前在本地测试和验证解决方案。 DevTools 中最强大但未充分利用的工具之一是覆盖功能。它允许您直接修改网络响应,让您在不改变生产环境的情况下模拟各种场景。

在本指南中,我们将向您展示如何安装 DevTools(如果您还没有安装)、如何逐步覆盖网络请求,并提供有关充分利用这个宝贵工具的提示。

为什么要使用网络覆盖?

想象一下能够调整 API 的响应或模拟失败的网络请求,所有这些都不会触及后端代码或影响您的用户。这正是网络覆盖赋予您的能力。无论您是否尝试:

  • 测试不同场景中缓慢或失败的网络请求。
  • 在后端准备好之前验证新功能。
  • 修改静态资源(如 CSS 或 JavaScript 文件)以调试样式或行为问题。

DevTools 为您提供了一个受控环境,您可以在其中进行调整、实验和验证——所有这些都在浏览器内进行。

安装 Chrome 开发者工具

如果您是网络开发人员,您的计算机上可能已经安装了 Google Chrome。但如果您尚未设置,请从 Chrome 官方网站下载。 Chrome DevTools 内置于浏览器中,因此安装后您就可以开始使用了。

专业提示:DevTools 也适用于其他基于 Chromium 的浏览器,如 Edge、Brave 和 Opera,尽管 Chrome 往往具有最新的功能。

DevTools 网络覆盖入门

如果您不熟悉 DevTools 或此功能,请按照以下简单步骤操作:

1. 打开开发工具

右键单击网页的任意元素,然后选择检查。这将打开 DevTools 界面。或者,您可以按 Ctrl Shift I (Windows/Linux) 或 Cmd Option I (Mac) 将其打开。

2. 导航到网络选项卡

DevTools 打开后,单击 Network 选项卡。在这里,您将看到您网站发出的每个网络请求的实时反馈。从 API 调用到图像加载,所有内容都会在此选项卡中记录和跟踪。如果列表看起来令人难以承受,您可以使用过滤器(例如用于 AJAX 请求的 XHR)来将视图范围缩小到最相关的请求。

3. 识别并覆盖特定请求

滚动浏览请求列表以找到您要修改的请求。例如,如果 API 返回错误结果或第三方脚本行为不当,您就可以进行干预。右键单击所需的请求并选择覆盖内容

Override and Mock Network Responses in DevTools

如果这是您第一次使用该功能,系统将提示您选择一个本地文件夹来存储您的覆盖。此文件夹将包含您的所有更改,以便以后轻松恢复到原始文件。

4. 编辑回复

选择本地文件夹后,您想要覆盖的响应将自动在 Sources 选项卡中打开。您可以在此处根据需要修改内容。无论是调整 JSON 响应、调整 JavaScript 函数还是修改 HTML 文件,您都可以自由地进行必要的更改。

专业提示:修改大文件时要小心,尤其是第三方库,因为它们可能包含关键函数。专注于特定部分以避免意外后果。

Override and Mock Network Responses in DevTools

5. 保存并刷新

完成编辑后,按 Ctrl S (Windows/Linux) 或 Cmd S (Mac) 保存文件。然后,刷新您的网页。这些更改现在将反映在您的本地环境中,允许您测试修改后的网络请求,就像它是实时的一样。

专业提示:请记住,这些更改仅适用于您的本地环境。如果您关闭浏览器或清除覆盖,原始请求将恢复。

高级用户的高级技巧

虽然上述步骤概述了覆盖网络响应的基础知识,但 Chrome DevTools 为那些希望将调试提升到新水平的人提供了更大的灵活性:

模拟网络状况

Chrome DevTools 还允许您模拟不同的网络条件。例如,如果您想测试应用程序在慢速 3G 连接或网络暂时不可用时的行为,您可以在 Network 选项卡下限制网络速度。只需单击标有 在线 的下拉菜单,然后选择所需的速度配置文件。

这对于确保您的应用程序在用户连接较差或带宽有限时正常降级特别有用。

多个文件的本地覆盖

需要一次覆盖多个文件?您可以将多个请求添加到覆盖文件夹,从而使您可以完全控制网站的多个方面。例如,您可以组合 CSS、JavaScript 和 API 响应覆盖来创建反映潜在现实场景的模拟环境,所有这些都无需更改一行生产代码。

跨会话持久覆盖

如果您经常处理同一个项目,Chrome DevTools 允许您在浏览器会话之间保留您的覆盖。这可以确保即使在关闭浏览器后,您的更改在下次打开它时仍然有效,从而节省您的时间和精力。

要启用此功能,请转到 DevTools 中的 Settings 菜单(齿轮图标),导航到 Overrides 部分,然后选中 Enable permanent overrides.

结论

Chrome DevTools 不仅仅用于检查元素或调试 JavaScript 错误,它还是一个非常强大的工具,可以显着增强您在实时环境中进行故障排除和实验的能力。通过学习覆盖和模拟网络响应,您可以测试不同的解决方案、模拟各种场景并验证更改,而不会影响您的生产站点。

无论您是经验丰富的开发人员还是新手,掌握 Chrome DevTools 中的覆盖功能都将提高您的调试技能,并让您在发布之前对所做的更改更有信心。所以,不要只是调试——更智能地调试!

版本声明 本文转载于:https://dev.to/geraldhamiltonwicks/override-and-mock-network-responses-in-devtools-166m?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    我可以将加密从McRypt迁移到OpenSSL,并使用OpenSSL迁移MCRYPT加密数据?
    将我的加密库从mcrypt升级到openssl 问题:是否可以将我的加密库从McRypt升级到OpenSSL?如果是这样,如何?答案:是的,可以将您的Encryption库从McRypt升级到OpenSSL。可以使用openssl。附加说明: [openssl_decrypt()函数要求iv参...
    编程 发布于2025-03-09
  • 如何使用不同数量列的联合数据库表?
    如何使用不同数量列的联合数据库表?
    合并列数不同的表 当尝试合并列数不同的数据库表时,可能会遇到挑战。一种直接的方法是在列数较少的表中,为缺失的列追加空值。 例如,考虑两个表,表 A 和表 B,其中表 A 的列数多于表 B。为了合并这些表,同时处理表 B 中缺失的列,请按照以下步骤操作: 确定表 B 中缺失的列,并将它们添加到表的末...
    编程 发布于2025-03-09
  • 为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    The Mystery of "Broken" Two-Phase Template Instantiation in Microsoft Visual C Problem Statement:Users commonly express concerns that Micro...
    编程 发布于2025-03-09
  • 对象拟合:IE和Edge中的封面失败,如何修复?
    对象拟合:IE和Edge中的封面失败,如何修复?
    解决此问题,我们采用了一个巧妙的CSS解决方案来解决问题:左:50%; 高度:auto; 宽度:100%; //对于水平块 ,使用绝对定位将图像定位在中心,以object-fit:object-fit:cover in IE和edge消除了问题。现在,图像将按比例扩展,保持所需的效果而不会失真。...
    编程 发布于2025-03-09
  • 为什么使用Firefox后退按钮时JavaScript执行停止?
    为什么使用Firefox后退按钮时JavaScript执行停止?
    导航历史记录问题:JavaScript使用Firefox Back Back 此行为是由浏览器缓存JavaScript资源引起的。要解决此问题并确保在后续页面访问中执行脚本,Firefox用户应设置一个空功能。 警报'); }; alert('inline Alert')...
    编程 发布于2025-03-09
  • 大批
    大批
    [2 数组是对象,因此它们在JS中也具有方法。 切片(开始):在新数组中提取部分数组,而无需突变原始数组。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    编程 发布于2025-03-09
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python import codecs import codecs import codecs 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有...
    编程 发布于2025-03-09
  • \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    \“(1)vs.(;;):编译器优化是否消除了性能差异?\”
    答案: 在大多数现代编译器中,while(1)和(1)和(;;)之间没有性能差异。编译器: perl: 1 输入 - > 2 2 NextState(Main 2 -E:1)V-> 3 9 Leaveloop VK/2-> A 3 toterloop(next-> 8 last-> 9 ...
    编程 发布于2025-03-09
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    在java 中有效地替换多个substring,需要在需要替换一个字符串中的多个substring的情况下,很容易求助于重复应用字符串的刺激力量。 However, this can be inefficient for large strings or when working with nu...
    编程 发布于2025-03-09
  • 如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    如何为PostgreSQL中的每个唯一标识符有效地检索最后一行?
    postgresql:为每个唯一标识符提取最后一行,在Postgresql中,您可能需要遇到与在数据库中的每个不同标识相关的信息中提取信息的情况。考虑以下数据:[ 1 2014-02-01 kjkj 在数据集中的每个唯一ID中检索最后一行的信息,您可以在操作员上使用Postgres的有效效率: ...
    编程 发布于2025-03-09
  • 如何从PHP中的数组中提取随机元素?
    如何从PHP中的数组中提取随机元素?
    从阵列中的随机选择,可以轻松从数组中获取随机项目。考虑以下数组:; 从此数组中检索一个随机项目,利用array_rand( array_rand()函数从数组返回一个随机键。通过将$项目数组索引使用此键,我们可以从数组中访问一个随机元素。这种方法为选择随机项目提供了一种直接且可靠的方法。
    编程 发布于2025-03-09
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-03-09
  • 可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    可以在纯CS中将多个粘性元素彼此堆叠在一起吗?
    [2这里: https://webthemez.com/demo/sticky-multi-header-scroll/index.html </main> <section> { display:grid; grid-template-...
    编程 发布于2025-03-09
  • 为什么PYTZ最初显示出意外的时区偏移?
    为什么PYTZ最初显示出意外的时区偏移?
    与pytz 最初从pytz获得特定的偏移。例如,亚洲/hong_kong最初显示一个七个小时37分钟的偏移: 差异源利用本地化将时区分配给日期,使用了适当的时区名称和偏移量。但是,直接使用DateTime构造器分配时区不允许进行正确的调整。 example pytz.timezone(...
    编程 发布于2025-03-09
  • 为什么我的CSS背景图像出现?
    为什么我的CSS背景图像出现?
    故障排除:CSS背景图像未出现 ,您的背景图像尽管遵循教程说明,但您的背景图像仍未加载。图像和样式表位于相同的目录中,但背景仍然是空白的白色帆布。而不是不弃用的,您已经使用了CSS样式: bockent {背景:封闭图像文件名:背景图:url(nickcage.jpg); 如果您的html,css...
    编程 发布于2025-03-09

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3