热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【Debug】既然天天都要Debug,何不从Debug技能着手呢?第一天

相信Debug是开发者每天必经的过程,能否顺利Debug决定了开发者一整天的心情,即使如此却较少看到开发者着墨在Debug技巧上,因此接下

在这里插入图片描述
相信Debug 是开发者每天必经的过程,能否顺利Debug 决定了开发者一整天的心情,即使如此却较少看到开发者着墨在Debug 技巧上,因此接下来的30 天中,我将会介绍各种前端Debug 技巧,还有我常用的小技巧,解救那些时常陷于Debug 之苦却难以脱身的网页开发者们。

缘起

一切的开始,就在第一次面试实习机会时,主考官问我:「你都怎么Debug?」我一时竟然只能想出一个答案:「开DevTools 看console.log。」那时候我的Debug原则就是「如果一个console.log 找不出问题,就放入更多的console.log!」虽然有时候会觉得自己很傻,不过大多时候还是能找出问题,便持续使用这个套路一路向前。

被问倒之后我开始反省自己的Debug 方式,明明每天都在使用DevTools,却总是只用到console.log,赶紧上网搜寻别人都是怎么解决问题的,看过一篇又一篇的文章后,惊觉自己对DevTools 的理解只是冰山一角,有太多好用的功能我竟然浑然不知,从此开启了我对DevTools 的摸索之路。

系列内容

这系列文章的内容主要围绕在前端相关的Debug 技巧,只要你有网页开发经验,尤其:

每天都会开启浏览器的Devtools

常常需要刻UI 以及撰写许多HTML、CSS

以Javascript 维生
需要进行前端性能、SEO 优化

都非常推荐阅读,这项目的内容将会以Chrome DevTools 为主,包含各个功能面板以及实用技巧及带入实际的Debug 情境协助理解,大部分的情境都是来自于笔者自己在开发过程中遇到的问题,或是曾经看过觉得十分有趣的例子,建议读者可在阅读文章时候搭配Demo 实际操作,帮助记忆及理解。

此外本系列大部分的章节是独立的,阅读顺序并不会造成太大的影响,除了Chrome DevTools 之外,还会提到关于Web Vitals、SEO 等网页指标的Debug 工具、与其他浏览器DevTools 的比较以及效能优化的议题,尽可能的涵盖各种前端Debug 情境。

在这里插入图片描述

以上为Core Web Vitals,是Google 在2020 年提出的核心网页体验指标

讲讲DevTools 之外的Debug 方式

Debug 时除了使用DevTools 之外,还有许多解决问题的方式,以下列出笔者自身的一些经验。

上网搜寻

许多问题可以靠Google 快速找到答案,当然也会有碰壁的时候,笔者刚在编程之路起步时,常常无法解决问题,然而经过一段时间后明显发觉Google 的能力提升了,能从更多的面向、资源去寻找答案,例如比起从Stack Overflow找到直接的答案,主动阅读MDN 文件、官方说明的FAQ 和Caveats、GitHub Issues 甚至是规范等时常会包含许多有用的信息。

询问周遭

向有经验的人、社群提问也是非常有效的方式,但前提是已经做过功课、走过研究的步骤,千万不要却步于提问,只要做好充足的准备,大部分的人都很乐于协助解决问题。另外提出明确的问题和足够的信息才能让大家对症下药,例如碰到难解的Bug 时,若其他人能够重现相同的错误,几乎100% 能够解决问题。

不要钻牛角尖

若发现无论怎么搜寻都难以找到解法,甚至都只有无关的信息,非常有可能是搜寻方向错了,例如实际出错的部分不是正在搜寻的套件,可能只是单纯程式码拼错、手误,才会出现特别的错误信息。笔者就曾经因为不小心按到Tab,让编辑器自动加入一些语法,程式开始奇怪的错误,找了一整天才发现问题所在。

放松身心

此外笔者认为放松也是Debug 重要的一环,当已经卡在某个Bug 几个小时,试试放松一下心情,离开键盘散步、买杯饮料,笔者就有不少次在洗澡的时候突然想到问题的解法呢!

问题与讨论

最后,对内容中提到的Debug 情境有不同甚至更好的解决方式、思维,都非常欢迎提出讨论,借此来交流一下Debug 流程,笔者认为这是非常有价值的经验分享。而对内容有任何疑问,或有发现任何错误,也请不吝提出,谢谢。


推荐阅读
  • 如何撰写适应变化的高效代码:策略与实践
    编写高质量且适应变化的代码是每位程序员的追求。优质代码的关键在于其可维护性和可扩展性。本文将从面向对象编程的角度出发,探讨实现这一目标的具体策略与实践方法,帮助开发者提升代码效率和灵活性。 ... [详细]
  • 在《Cocos2d-x学习笔记:基础概念解析与内存管理机制深入探讨》中,详细介绍了Cocos2d-x的基础概念,并深入分析了其内存管理机制。特别是针对Boost库引入的智能指针管理方法进行了详细的讲解,例如在处理鱼的运动过程中,可以通过编写自定义函数来动态计算角度变化,利用CallFunc回调机制实现高效的游戏逻辑控制。此外,文章还探讨了如何通过智能指针优化资源管理和避免内存泄漏,为开发者提供了实用的编程技巧和最佳实践。 ... [详细]
  • 触发器的稳态数量分析及其应用价值
    本文对数据库中的SQL触发器进行了稳态数量的详细分析,探讨了其在实际应用中的重要价值。通过研究触发器在不同场景下的表现,揭示了其在数据完整性和业务逻辑自动化方面的关键作用。此外,还介绍了如何在Ubuntu 22.04环境下配置和使用触发器,以及在Tomcat和SQLite等平台上的具体实现方法。 ... [详细]
  • 第六章:枚举类型与switch结构的应用分析
    第六章深入探讨了枚举类型与 `switch` 结构在编程中的应用。枚举类型(`enum`)是一种将一组相关常量组织在一起的数据类型,广泛存在于多种编程语言中。例如,在 Cocoa 框架中,处理文本对齐时常用 `NSTextAlignment` 枚举来表示不同的对齐方式。通过结合 `switch` 结构,可以更清晰、高效地实现基于枚举值的逻辑分支,提高代码的可读性和维护性。 ... [详细]
  • 深入解析HTML5字符集属性:charset与defaultCharset
    本文将详细介绍HTML5中新增的字符集属性charset和defaultCharset,帮助开发者更好地理解和应用这些属性,以确保网页在不同环境下的正确显示。 ... [详细]
  • Python 数据可视化实战指南
    本文详细介绍如何使用 Python 进行数据可视化,涵盖从环境搭建到具体实例的全过程。 ... [详细]
  • [转]doc,ppt,xls文件格式转PDF格式http:blog.csdn.netlee353086articledetails7920355确实好用。需要注意的是#import ... [详细]
  • 开机自启动的几种方式
    0x01快速自启动目录快速启动目录自启动方式源于Windows中的一个目录,这个目录一般叫启动或者Startup。位于该目录下的PE文件会在开机后进行自启动 ... [详细]
  • 全面解析JavaScript代码注释技巧与标准规范
    在Web前端开发中,JavaScript代码的可读性和维护性至关重要。本文将详细介绍如何有效地使用注释来提高代码的可读性,并探讨JavaScript代码注释的最佳实践和标准规范。通过合理的注释,开发者可以更好地理解和维护复杂的代码逻辑,提升团队协作效率。 ... [详细]
  • 帝国CMS中的信息归档功能详解及其重要性
    本文详细解析了帝国CMS中的信息归档功能,并探讨了其在内容管理中的重要性。通过归档功能,用户可以有效地管理和组织大量内容,提高网站的运行效率和用户体验。此外,文章还介绍了如何利用该功能进行数据备份和恢复,确保网站数据的安全性和完整性。 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • Linux基础知识:Vi与Vim编辑器详解
    Linux基础知识:Vi与Vim编辑器详解 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • CSS3 @font-face 字体应用技术解析与实践
    在Web前端开发中,HTML教程和CSS3的结合使得网页设计更加多样化。长期以来,Web设计师受限于“web-safe”字体的选择。然而,CSS3中的`@font-face`规则允许从服务器端加载自定义字体,极大地丰富了网页的视觉效果。通过这一技术,设计师可以自由选择和使用各种字体,提升用户体验和页面美观度。本文将深入解析`@font-face`的实现原理,并提供实际应用案例,帮助开发者更好地掌握这一强大工具。 ... [详细]
  • 在使用 SQL Server 时,连接故障是用户最常见的问题之一。通常,连接 SQL Server 的方法有两种:一种是通过 SQL Server 自带的客户端工具,例如 SQL Server Management Studio;另一种是通过第三方应用程序或开发工具进行连接。本文将详细分析导致连接故障的常见原因,并提供相应的解决策略,帮助用户有效排除连接问题。 ... [详细]
author-avatar
BBCong
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有