0

0

如何利用Performance API进行前端性能深度分析?

夜晨

夜晨

发布时间:2025-09-28 10:50:02

|

797人浏览过

|

来源于php中文网

原创

Performance API 可精确采集页面加载、渲染及核心网页指标,通过 PerformanceObserver 监听 LCP、FID、CLS 等数据,结合 getEntriesByType 分析资源加载性能,并在 load 后上报至服务端,实现持续监控与瓶颈定位。

如何利用performance api进行前端性能深度分析?

前端性能直接影响用户体验,而浏览器提供的 Performance API 是进行深度性能分析的核心工具。它能提供页面加载、资源请求、脚本执行等关键时间点的精确数据,帮助开发者定位瓶颈。

理解 Performance API 的核心接口

Performance API 包含多个子接口,用于采集不同类型的数据:

  • performance.timing:已废弃,建议使用 Navigation Timing Level 2
  • performance.navigation:获取导航类型(如刷新、前进/后退)和重定向次数
  • PerformanceObserver:监听新性能条目(如 LCP、FID、CLS)的推荐方式
  • performance.getEntries():获取所有已记录的性能条目,包括资源加载、Paint、Navigation 等
注意:现代应用应优先使用 PerformanceObserver 配合 entryTypes 监听关键指标,避免遗漏异步生成的性能数据。

采集关键性能指标(Core Web Vitals)

Google 推出的核心网页指标是衡量用户体验的关键,Performance API 支持通过 PerformanceObserver 捕获:

  • LCP(最大内容绘制):监听 largest-contentful-paint 类型条目,判断主内容渲染时间
  • FID(首次输入延迟):监听 first-input,测量用户首次交互的响应延迟
  • CLS(累积布局偏移):监听 layout-shift,检测页面意外布局变化

示例代码:

立即学习前端免费学习笔记(深入)”;

PDFlux
PDFlux

PDF内容提取+智能问答神器,结合了科研级精准的非结构化文档解析能力,以及ChatGPT的智能问答能力。

下载

const observer = new PerformanceObserver((list) => {
  for (const entry of list.getEntries()) {
    console.log(entry.name, entry.startTime, entry.value);
  }
});
observer.observe({ entryTypes: ['largest-contentful-paint', 'first-input', 'layout-shift'] });

分析资源加载与渲染性能

通过 performance.getEntriesByType('navigation') 可获取页面加载全过程的时间节点:

  • domContentLoadedEventEnd:DOM 解析完成并执行完同步脚本
  • loadEventEnd:页面所有资源(如图片、iframe)加载完成
  • secureConnectionStart:HTTPS 握手开始时间,可用于计算 TLS 耗时

资源级别分析可通过 getEntriesByType('resource') 获取每个脚本、样式、图片的加载耗时、DNS 查询、TCP 连接等细节,识别慢资源。

上报与持续监控

采集到的数据需上报至服务端进行聚合分析。建议在 window.onload 后发送,避免影响关键渲染路径:


window.addEventListener('load', () => {
  setTimeout(() => {
    const navigation = performance.getEntriesByType('navigation')[0];
    const resources = performance.getEntriesByType('resource');
    // 发送数据到分析后台
    navigator.sendBeacon('/log', JSON.stringify({ navigation, resources }));
  }, 1000);
});

结合日志系统可建立性能基线,设置告警阈值,及时发现回归问题。

基本上就这些。合理使用 Performance API 能深入掌握前端性能表现,关键是持续采集、对比趋势、定位瓶颈。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

139

2023.12.20

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

980

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

38

2025.10.17

DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

2639

2024.08.14

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.11.24

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1518

2024.08.16

iframe写法有哪些
iframe写法有哪些

iframe写法有基本Iframe写法、嵌套Iframe写法、自适应宽高的Iframe写法、带有样式和属性的Iframe写法、内联Iframe写法和使用JavaScript动态创建Iframe写法。种写法都有自己的特点和适用场景。根据实际需求,选择合适的写法可以实现所需的功能和效果。

476

2023.10.19

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

115

2025.12.24

拼豆图纸在线生成器
拼豆图纸在线生成器

拼豆图纸生成器有PixelBeads在线版、BeadGen和“豆图快转”;推荐通过pixelbeads.online或搜索“beadgen free online”直达官网,避开需注册的诱导页面。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

84

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号