前端首屏加载优化

21 阅读3分钟

前端首屏加载优化

脱离八股、工程可落地、面试能加分的首屏优化方案,覆盖预加载、关键资源、延迟策略、SSR/SSG、工程化等核心要点。


方案总览

策略手段收益
预加载preload / prefetch / preconnect / fetchpriority精准提速关键资源
关键 CSS首屏样式内联,非关键异步消除渲染阻塞
图片/字体懒加载 + 现代格式 + font-display减少首屏下载量
JS 延迟defer / async / 动态 import根治脚本阻塞
预渲染prerender-spa-pluginSPA 首屏秒开
SSR/SSGNext.js / Nuxt.jsSEO 友好、首屏极快
服务端Gzip/Brotli、CDN、缓存传输层提速
工程化代码分割 + Bundle 分析 + 监控持续优化闭环

一、预加载(精准提速)

preload — 高优加载首屏必需资源

<link rel="preload" href="core.js" as="script">
<link rel="preload" href="font.woff2" as="font" type="font/woff2" crossorigin>

prefetch — 低优预加载未来可能用到的资源

不阻塞当前渲染,空闲时加载下一跳页面资源。

preconnect — 提前建立域名连接

减少 DNS / TLS 握手耗时:

<link rel="preconnect" href="https://cdn.example.com">

fetchpriority — 指定关键资源优先级

<img src="poster.jpg" fetchpriority="high">

二、关键 CSS(消除渲染阻塞)

核心思路: 首屏样式内联,非关键样式异步加载。

工程化提取

构建工具方案
Webpackmini-css-extract-plugin + critical-css-webpack-plugin
Vitevite-plugin-critical
通用工具Critical、Penthouse 自动提取首屏 CSS

写法

<style>/* 内联首屏关键 CSS */</style>
<link rel="stylesheet" href="all.css" media="print" onload="this.media='all'">

三、图片 / 字体优化

措施具体方案
关键图优先首屏图用 preload + fetchpriority="high"
懒加载非首屏图 loading="lazy"IntersectionObserver
现代格式WebP / AVIF,配合 srcset 响应式尺寸
字体font-display: swap 避免 FOIT,WOFF2 压缩

四、JS 延迟 / 异步(根治阻塞)

属性执行时机阻塞渲染适用场景
deferHTML 解析完、DOMContentLoaded 前依赖 DOM、需按顺序执行
async加载完立即执行独立脚本、无依赖

最佳实践

核心业务   → 内联或高优加载
统计/广告  → async
组件库/路由 → 动态 import + 代码分割
const Chart = React.lazy(() => import('./Chart'));

五、预渲染(SPA 首屏神器)

适用: 静态路由、无大量动态数据。

构建工具方案
Webpackprerender-spa-plugin

构建时生成完整 HTML,直接吐出首屏内容:

document.dispatchEvent(new Event('render-event'));

六、SSR / SSG(终极方案)

方案原理框架
SSR服务端直出 HTML,首屏极快、SEO 友好React → Next.js / Vue → Nuxt.js
SSG构建时生成静态页,访问秒开Next.js / Nuxt / Astro

加分项: 边缘渲染、流式 SSR、渐进式注水


七、服务端与传输优化

措施说明
Gzip / Brotli开启压缩,Brotli 比 Gzip 压缩率高 ~20%
HTTP/2 Server Push推送关键资源,减少往返
CDN静态资源就近分发
缓存强缓存 Cache-Control + 协商缓存 ETag

八、工程化与监控

维度工具 / 指标
代码分割路由级 / 组件级 / 第三方库拆分
打包分析Webpack Bundle Analyzer、Rollup Visualizer
性能指标LCP、FCP、TTI、CLS
监控Lighthouse、Web Vitals、Performance API

九、话术

1. 关键路径优化:内联关键 CSS、预加载核心资源、图片/字体极致压缩
2. 加载策略分层:同步 / 异步 / 懒加载 / 预加载
3. 框架层:SPA → 预渲染,大型应用 → SSR / SSG
4. 工程 + 服务:压缩、缓存、CDN、Server Push
5. 量化监控,持续迭代