概述性能指标采集有助于优化端到端体验。本文给出采集与持久化方案。采集与持久化const supportsPO = typeof PerformanceObserver === 'function';

function openDB(name) {

return new Promise((resolve, reject) => {

const r = indexedDB.open(name, 1);

r.onupgradeneeded = () => { const db = r.result; if (!db.objectStoreNames.contains('metrics')) db.createObjectStore('metrics', { autoIncrement: true }); };

r.onsuccess = () => resolve(r.result);

r.onerror = () => reject(r.error);

});

}

async function saveMetric(rec) {

const db = await openDB('perf');

const tx = db.transaction('metrics', 'readwrite');

tx.objectStore('metrics').add(rec);

await new Promise((resolve, reject) => { tx.oncomplete = resolve; tx.onerror = () => reject(tx.error); });

db.close();

}

function startCollect() {

if (!supportsPO) return;

const po = new PerformanceObserver(list => {

for (const entry of list.getEntries()) saveMetric({ name: entry.name, value: entry.value, ts: entry.startTime });

});

po.observe({ type: 'largest-contentful-paint', buffered: true });

po.observe({ type: 'first-input', buffered: true });

po.observe({ type: 'layout-shift', buffered: true });

}

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论
立即
投稿

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部