网站首页 > 技术文章 正文
在前端开发中,性能优化是一个非常重要的方面。如果我们的网站或应用程序加载速度慢,用户体验就会受到影响,甚至可能导致用户流失。因此,我们需要了解如何使用工具来检测和解决前端性能问题。在本文中,我将介绍如何使用谷歌浏览器调试器的Performance选项卡来发现前端性能问题。
性能(Performance)选项卡
点击左上角的录制按钮,开始记录性能数据。
在网站或应用程序中执行一些操作,例如加载页面、点击按钮等。
停止录制并查看性能数据。可以看到各种性能指标,例如加载时间、CPU使用率、内存使用率等。
分析性能数据并找出潜在的性能问题。例如,如果加载时间很长,可能是因为页面中有太多的资源需要加载,或者因为服务器响应时间很慢。
最上面出现一条红线,表示这里有性能问题,红线间是断开的,没小段表示从js的执行到最终渲染这段时间,正常情况这段时间应该跟帧率相同约为16.67毫秒(一秒钟60帧),当这段时间大于16.7毫秒用户就会感觉到卡;
红线下面的波形图,黄色呢代表js 的执行,紫色代表渲染的执行,绿色代表浏览器绘制执行,其中紫色占面积最大,说明造成的性能问题主要发生在渲染过程中,在最下面的Summary中同样可以看出Rendering占用时间最长;
再往下是屏幕快照,勾选Screenshots时显示。
下面还有很多子菜单,最常用的是Main,它表示浏览器的渲染主线程,里面每一个方格代表一个任务(横向表示一个个任务,纵向表示调用栈),红色三角形代表这个任务运行时间过长。
用鼠标点击上面时间线部分会出现两个滑块(再双击查看全部),通过调整滑块可以进入某一个时间的切面详细观察当前任务详情。Animation Frame Fired是window.requestAnimationFrame(callback),Funcation Call是requestAnimationFrame的callback,callback执行的是app.update,现在基本上找到了问题出现的位置
点击app.update,再点击Call Tree(执行树)查看耗时详情,找到耗时最多的位置,点击后面链接可以直接定位到耗时代码。
- 上一篇: 使用chrome调试工具解决问题(五)
- 下一篇: 使用chrome调试工具解决问题(六)
猜你喜欢
- 2024-11-19 记某次常规js前端逆向
- 2024-11-19 前端代码安全与混淆
- 2024-11-19 前端抓包神器--whistle
- 2024-11-19 使用chrome调试工具解决问题(六)
- 2024-11-19 使用chrome调试工具解决问题(五)
- 2024-11-19 使用chrome调试工具解决问题(四)
- 2024-11-19 使用chrome调试工具解决问题(三)
- 2024-11-19 楼宇自控系统设备的安装与调试
- 2024-11-19 使用chrome调试工具解决问题(一)
- 2024-11-19 桌面端|Electron 几个开发调试小技巧
你 发表评论:
欢迎- 最近发表
-
- 前端流行框架Vue3教程:13. 组件传递数据_Props
- 前端必看!10 个 Vue3 救命技巧,解决你 90% 的开发难题?
- JAVA和JavaScript到底是什么关系?是亲戚吗?
- Java和js有什么区别?(java和javascript的区别和联系)
- 东方标准|Web和Java的区别,如何选择这两个专业
- 前端面试题-JS 中如何实现大对象深度对比
- 360前端一面~面试题解析(360前端笔试)
- 加班秃头别慌!1 道 Vue 面试题,快速解锁大厂 offer 通关密码
- 焦虑深夜刷题!5 道高频 React 面试题,吃透 offer 稳了
- 2025Web前端面试题大全(整理版)面试题附答案详解,最全面详细
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle查询数据库 (45)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)