JavaScript性能监控_PerformanceAPI

Performance API通过高精度时间戳提供页面加载、资源请求等性能数据。1. 使用performance.now()获取精确时间;2. 用mark和measure测量自定义逻辑耗时;3. 通过navigation条目计算DNS、TCP、白屏等关键指标;4. 利用PerformanceObserver监听动态资源加载。结合上报机制可构建完整前端监控体系,持续优化用户体验。

javascript性能监控_performanceapi

前端性能监控是优化用户体验的关键环节,JavaScript中的Performance API为开发者提供了精确测量应用性能的能力。它基于高精度时间戳,能帮助我们获取页面加载、资源请求、脚本执行等关键阶段的耗时信息。

Performance API 核心功能

Performance API 是浏览器内置的接口,位于 window.performance 对象下,主要包含以下几个核心部分:

performance.now():返回自页面加载以来的高精度时间(毫秒),比 Date.now() 更精确,不受系统时钟调整影响。performance.timing:提供页面加载各个阶段的时间戳(已废弃,推荐使用 Navigation Timing Level 2)。performance.getEntries():获取所有已记录的性能条目,包括资源加载、Paint、Frame 等。performance.mark()performance.measure():用于自定义打点和测量时间段。

使用 mark 和 measure 进行自定义性能测量

在复杂应用中,我们常需要测量某段逻辑的执行时间,比如接口响应、组件渲染等。利用 mark 和 measure 可轻松实现:

// 打标记performance.mark('start-data-fetch');

fetch('/api/data').then(res => res.json()).then(data => {performance.mark('end-data-fetch');// 记录耗时performance.measure('data-fetch-time', 'start-data-fetch', 'end-data-fetch');});

之后可通过 performance.getEntriesByType(‘measure’) 获取测量结果:

立即学习“Java免费学习笔记(深入)”;

const measures = performance.getEntriesByType('measure');console.log(measures); // [{ name: "data-fetch-time", duration: 120.5, ... }]

监控页面加载性能

利用 navigationStartloadEventEnd 等时间点,可以计算关键性能指标:

const perfData = performance.getEntriesByType("navigation")[0];console.log(`DNS查询耗时: ${perfData.domainLookupEnd - perfData.domainLookupStart}`);console.log(`TCP连接耗时: ${perfData.connectEnd - perfData.connectStart}`);console.log(`白屏时间: ${perfData.responseStart - perfData.navigationStart}`);console.log(`DOM渲染完成: ${perfData.domContentLoadedEventEnd - perfData.navigationStart}`);console.log(`页面完全加载: ${perfData.loadEventEnd - perfData.navigationStart}`);

结合 PerformanceObserver 监听动态资源

对于异步加载的资源(如图片、脚本),可使用 PerformanceObserver 实时监听:

const observer = new PerformanceObserver((list) => {  for (const entry of list.getEntries()) {    console.log(`${entry.name} 加载耗时: ${entry.duration}`);    // 可上报到服务器  }});// 观察资源加载observer.observe({ entryTypes: ['resource'] });

这种方式适用于懒加载图片、动态 import 等场景,能更全面地掌握运行时性能表现。

基本上就这些。Performance API 提供了从页面加载到运行时测量的完整能力,合理使用可以帮助我们定位瓶颈、优化体验,并建立可持续的前端监控体系。不复杂但容易忽略细节,建议结合上报机制长期跟踪。

以上就是JavaScript性能监控_PerformanceAPI的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1539272.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月21日 11:27:23
下一篇 2025年12月21日 11:27:40

相关推荐

  • JavaScript密码学_WebCryptoAPI加密解密实战

    WebCrypto API 提供加密、解密、签名等功能,支持 AES-GCM 对称加密和 RSA-OAEP 非对称加密,通过 generateKey 创建密钥,encrypt/decrypt 实现数据加解密,exportKey/importKey 管理密钥,需配合 HTTPS 与后端保障安全。 We…

    2025年12月21日
    000
  • JavaScript消息队列_Redis发布订阅模式

    答案:使用Node.js的redis包实现Redis发布订阅,先用redis.createClient()创建连接,通过subscribe或psubscribe监听频道并设置on(‘message’)回调处理消息,另一端用publish发送JSON格式消息,注意错误处理与连接…

    2025年12月21日
    000
  • 数组操作方法大全_javascript数据处理

    JavaScript数组操作方法涵盖增删改查、遍历、排序等场景,1. 增加元素用push、unshift、splice或concat;2. 删除元素用pop、shift、splice或filter;3. 遍历查找可用forEach、map、find、findIndex、some和every;4. 排…

    2025年12月21日
    000
  • 网络爬虫编写_javascript数据采集

    使用Puppeteer或Selenium模拟浏览器执行JavaScript,结合分析网络请求直接调用API,并设置合理请求头、Cookie及反爬策略,可高效采集动态渲染页面数据。 面对JavaScript渲染的网页数据采集,传统爬虫直接请求HTML的方式往往无法获取完整内容,因为很多数据是通过前端J…

    2025年12月21日
    000
  • JavaScript 错误监控:Source Map 还原线上错误

    Source Map 是记录压缩代码与源码位置映射的 JSON 文件,包含 sources、names 和 mappings 等字段。构建时需通过 Webpack 或 Vite 配置生成 map 文件并妥善部署。前端通过 onerror 和 unhandledrejection 捕获错误,上报脚本地…

    2025年12月21日
    000
  • 浏览器API_Intersection Observer使用

    Intersection Observer API用于监听元素是否进入视口,支持懒加载、动画触发和埋点上报。通过创建observer实例并配置threshold、rootMargin等参数,可在元素可见时执行回调,相比scroll事件更高效。典型应用包括图片懒加载(读取data-src)、视入动画(…

    2025年12月21日
    000
  • JavaScript通知API_桌面提醒功能开发

    JavaScript通知API需先获用户授权,通过Notification.requestPermission()请求,获准后用new Notification()创建提醒,并支持点击跳转等交互,同时需处理不兼容或拒绝情况,确保体验友好。 JavaScript通知API可以让网页在用户设备的桌面显示…

    2025年12月21日
    000
  • JavaScript缓存策略_Service Worker离线存储

    Service Worker 是实现离线缓存的核心技术,通过拦截网络请求并结合 Cache API 管理资源,支持缓存优先、网络优先等多种策略;需注册、安装、激活并监听 fetch 事件来控制缓存,版本更新时应清理旧缓存以确保生效。 Service Worker 是实现 JavaScript 缓存和…

    2025年12月21日
    000
  • JavaScript时间处理_时区转换与日历组件

    JavaScript的Date对象基于UTC存储时间戳但显示时转为本地时区,处理时区和日历需注意:构造函数解析字符串时区分是否含时区信息,推荐使用toISOString输出UTC时间;跨时区显示可用toLocaleString配合timeZone选项(如America/New_York);构建日历时…

    2025年12月21日
    000
  • JavaScript防抖与节流_性能优化实践

    防抖和节流是前端优化高频事件的两种手段:防抖通过延迟执行并仅响应最后一次操作,适用于搜索输入等场景;节流则保证固定时间间隔内最多执行一次,适合滚动监听等持续响应需求。 在前端开发中,频繁触发的事件(如窗口滚动、输入框输入、鼠标移动)容易导致性能问题。为优化这类场景,防抖(Debounce)和节流(T…

    2025年12月21日
    000
  • JavaScript缓存策略_CDN与边缘计算优化

    通过浏览器缓存、CDN加速与边缘计算协同优化JavaScript加载。1. 浏览器强缓存配合内容哈希实现长期缓存与自动更新;2. CDN将JS分发至全球节点,降低延迟并提升可用性;3. 边缘计算在近用户端执行逻辑,支持动态注入与请求预处理;4. 综合策略包括资源分离、缓存协调与边缘增强,构建高效交付…

    2025年12月21日
    000
  • Angular递归组件实现动态导航菜单:基于配置高效构建复杂UI

    本文详细介绍如何在angular应用中利用递归组件模式,根据动态配置数据生成多级导航菜单。通过定义清晰的数据接口和构建可复用的组件,我们能够高效地渲染任意深度的嵌套菜单,从而提升代码的可维护性和扩展性,并实现基于层级的动态样式和行为控制。 引言 在现代Web应用开发中,动态生成复杂的用户界面元素,尤…

    2025年12月21日
    000
  • 深入理解JavaScript中setTimeout的执行机制与事件循环

    javascript的`settimeout`函数提供了一个最小延迟,但其回调的实际执行时间并非绝对精确。这是因为javascript是单线程的,并且依赖事件循环机制。长时间运行的同步代码会阻塞主线程,导致`settimeout`的回调函数在指定延迟结束后,仍需等待调用栈清空才能被执行。 在Java…

    2025年12月21日
    000
  • JavaScript代码规范_ESLint插件开发

    ESLint插件开发需创建含rules、configs的npm包,如eslint-plugin-myteam;编写规则函数遍历AST节点,例如禁止console.log需监听MemberExpression并用context.report报错;通过RuleTester测试有效与无效代码案例;发布后在…

    2025年12月21日
    000
  • JavaScript尾调用优化_递归性能提升方法

    尾调用优化通过重用栈帧避免递归中的栈溢出,当函数最后一步调用自身且满足条件时生效,如阶乘函数中传递累加器参数实现尾递归。 JavaScript中的尾调用优化(Tail Call Optimization, TCO)是一种提升递归函数性能的技术,它能避免因深层递归导致的栈溢出问题。虽然并非所有环境都支…

    2025年12月21日
    000
  • JavaScript算法优化_时间复杂度分析与改进

    时间复杂度是衡量算法效率的核心指标,优化可提升性能与体验。1. 理解O(1)、O(n)、O(n²)、O(log n)等表示法,识别高复杂度操作;2. 减少嵌套循环,如用哈希表将两数之和从O(n²)降为O(n);3. 善用Set、Map及内置方法filter、map等提高效率;4. 排序预处理结合双指…

    2025年12月21日
    000
  • JavaScript模块联邦_微前端架构设计

    模块联邦是Webpack 5实现微前端的核心技术,支持运行时动态加载远程子应用模块。主应用通过remotes引用子应用,子应用通过exposes暴露组件,shared配置共享依赖。例如主应用配置remotes引入remoteApp@http://localhost:3001/remoteEntry.…

    2025年12月21日
    000
  • 使用 WebSocket 连接 SignalR Hub 时无法接收消息的解决方案

    本文旨在解决在使用原生 WebSocket 连接 SignalR Hub 时,客户端无法接收到服务端推送消息的问题。文章将分析可能的原因,并提供一种通过修改 SignalR 库的导入方式来解决问题的方案,从而避免使用 SignalR 库时出现的构建错误。 当尝试使用 WebSocket 直接连接 S…

    2025年12月21日
    000
  • JS模块导入怎么实现_JS模块化importexport语法使用指南

    JavaScript模块化通过export和import实现代码拆分与复用,支持命名导出、默认导出及动态导入,需注意文件扩展名、type=”module”设置及服务器运行环境。 JavaScript 模块化让开发者能将代码拆分成多个文件,提高可维护性和复用性。通过 impor…

    2025年12月21日
    000
  • 如何用js脚本制作轮播图_js轮播图效果实现与脚本编写步骤

    轮播图通过HTML结构、CSS样式和JavaScript交互实现图片切换。1. HTML构建容器、图片列表、按钮和指示点;2. CSS设置图片横向排列与过渡效果;3. JS控制索引切换、按钮响应、自动播放及指示点联动;4. 可扩展鼠标悬停暂停、触摸滑动等优化功能。 轮播图是网页中常见的交互组件,用于…

    2025年12月21日 好文分享
    000

发表回复

登录后才能评论
关注微信