应使用 requestIdleCallback 在主线程空闲时执行非关键任务,不支持时降级为 setTimeout;避免 DOMContentLoaded 前同步脚本阻塞;用 IntersectionObserver 替代 scroll 懒加载;关键 CSS 需内联,非关键异步加载。
requestIdleCallback 延迟非关键 JS 执行浏览器主线程空闲时才执行低优先级任务,避免阻塞渲染。适合处理日志上报、预加载非首屏资
源、DOM 渲染后微调等场景。
requestIdleCallback 不是所有环境都支持(如 Safari 旧版本),需用 setTimeout 降级deadline.timeRemaining() > 0,不能假设能跑完全部逻辑if ('requestIdleCallback' in window) {
requestIdleCallback(() => {
// 非关键逻辑,比如埋点采集
sendAnalytics();
}, { timeout: 2000 });
} else {
setTimeout(sendAnalytics, 0);
}
DOMContentLoaded 前执行大量同步脚本HTML 解析遇到 标签会暂停构建 DOM 树,直到脚本下载、解析、执行完成。这是首屏延迟的常见元凶。
放在