使用PerformanceObserver API 封装 useFirstContentfulPaint(FCP)

计算首屏时间的几种方式

性能监控工具 :性能监控工具如 Google Chrome 的开发者工具( Performance 面板)、Lighthouse 等提供了详细的性能分析和首屏渲染时间的度量。

Navigation Timing API :使用浏览器提供的 Navigation Timing API 来获取有关页面加载和渲染的性能数据。

js 复制代码
const performanceData = window.performance.timing;
const fcpTime = performanceData.msFirstPaint; // 首次绘制时间
console.log(`FCP 时间:${fcpTime}ms`);

标准的 paint 事件 :通过添加事件监听器来监听paint事件,然后捕获FCP事件。

js 复制代码
window.addEventListener('paint', (event) => {
  if (event.name === 'first-contentful-paint') {
    console.log(`FCP 时间:${event.startTime}ms`);
  }
});

PerformanceObserver API:监视各种性能事件。

PerformanceObserver

PerformanceObserver 可用于获取性能相关的数据,例如首帧fp首屏fcp首次有意义的绘制 fmp等。

PerformanceObserver() 创建并返回一个新的 PerformanceObserver 对象。

提供的方法

PerformanceObserver.observe():当记录的性能指标在指定的 entryTypes 之中时,将调用性能观察器的回调函数。

entryTypes 取值:longtask、frame、navigation、resource、mark、measure、paint

PerformanceObserver.disconnect():停止性能观察者回调接收到性能指标。

PerformanceObserver.takeRecords():返回存储在性能观察器中的性能指标的列表,并将其清空。

FP和FCP的关系

First Paint(FP):是指在浏览器首次将像素呈现在屏幕上的时间点,它不一定代表页面内容的可用性。

First Contentful Paint(FCP):是指在浏览器首次呈现页面的内容,即首次绘制任何文本、图像或其他内容的时间点,考虑了页面上的第一个可见内容,因此它通常在 FP 后发生,但它更关注用户体验。

useFirstContentfulPaint

js 复制代码
import { useEffect } from 'react';

function useFirstContentfulPaint() {
  useEffect(() => {
    const observer = new PerformanceObserver(list => {
      const entries = list.getEntries();
      for (const entry of entries) {
        if (entry.name === 'first-contentful-paint') {
          console.log(`First Contentful Paint: ${entry.startTime}ms`);
        }
      }
    });
    observer.observe({ type: 'paint', buffered: true });
    
    return () => observer.disconnect();
  }, []);

  return null;
}

export default useFirstContentfulPaint;
js 复制代码
import { onMounted, onBeforeUnmount } from 'vue';

export default function useFirstContentfulPaint() {
  const observer = new PerformanceObserver(list => {
    const entries = list.getEntries();
    for (const entry of entries) {
      if (entry.name === 'first-contentful-paint') {
        console.log(`First Contentful Paint: ${entry.startTime}ms`);
      }
    }
  });

  onMounted(() => {
    observer.observe({ type: 'paint', buffered: true });
  });

  onBeforeUnmount(() => {
    observer.disconnect();
  });

  return null;
}
相关推荐
少年姜太公4 小时前
什么?还不知道git cherry pick?
前端·javascript·git
白兰地空瓶6 小时前
🏒 前端 AI 应用实战:用 Vue3 + Coze,把宠物一键变成冰球运动员!
前端·vue.js·coze
Liu.7747 小时前
vue3使用vue3-print-nb打印
前端·javascript·vue.js
松涛和鸣7 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
dly_blog8 小时前
Vue 逻辑复用的多种方案对比!
前端·javascript·vue.js
万少8 小时前
HarmonyOS6 接入分享,原来也是三分钟的事情
前端·harmonyos
烛阴8 小时前
C# 正则表达式:量词与锚点——从“.*”到精确匹配
前端·正则表达式·c#
wyzqhhhh8 小时前
京东啊啊啊啊啊
开发语言·前端·javascript
JIngJaneIL8 小时前
基于java+ vue助农电商系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot·后端
q_19132846959 小时前
基于Springboot+MySQL+RuoYi的会议室预约管理系统
java·vue.js·spring boot·后端·mysql·若依·计算机毕业设计