javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > 前端首屏加载速度慢

前端面试官常问之首屏加载速度慢怎么解决

作者:程序员小寒

前端页面的首次加载过慢和资源加载顺序错乱是前端性能优化与工程化开发中的高频核心问题,且二者常伴随出现,这篇文章主要介绍了前端面试官常问之首屏加载速度慢怎么解决的相关资料,需要的朋友可以参考下

在前端面试中,首屏优化一直是常见的前端性能面试题。

我们可以先用 performance 相关API 来统计下页面的 DOM 加载时间

旧版统计方法,使用 performance:

// 旧版统计性能 performance.timing 已废弃,不推荐使用
window.onload = () => {
  console.log(performance.timing.domComplete - performance.timing.navigationStart);
}

新版统计方法,使用 PerformanceObserver (推荐使用):

// 新版统计性能 推荐使用
window.onload = () => {
  const observer = new PerformanceObserver((list) => {
    list.getEntries().forEach(entry => {
      console.log(entry.domComplete);
    })
  })
  observer.observe({ entryTypes: ['navigation'] })
}

如果 DOM加载时间 过长,比如超过 1s,就需要考虑进行优化了,优化的话主要从以下几个方向进行:

一、网络资源请求

1.1 减少请求个数

1.2 加快请求速度

二、构建工具

这里以 webpack 为例。

2.1 按需打包

对于一些第三方包,我们有时候并不会用到包里全部的内容,这时候就可以根据自己使用的部分进行按需打包,以减少打包后的文件体积。比如 Element-UI、Vant 等组件库、lodash、moment 等三方包。

2.2 代码分割 splitChunks

可以手动配置 splitChunks 进行代码分割:

  1. 将一些不怎么变动的包提取到一起,提高缓存复用率。
  2. 一些比较大的包,可以单独进行代码分割,按需加载
  3. 使用异步组件异步路由会自动进行代码分割,推荐将路由都设置为异步加载,一些比较大的组件,可以定义为异步组件,按需再加载。

2.3 配置 externals

externals 的作用是可以让某些特定的依赖不打包到最终的 bundle 中,这样可以大大减少打包后的包体积。

2.4 开启 tree-shaking

tree-shaking 摇树优化能消除未使用的代码,减少打包体积。

2.5 开启 gzip 压缩

可以使用 compression-webpack-plugin 在打包过程中对资源文件进行压缩,并在服务器开启 gzip,比如如果前端静态资源服务器用的 nginx,就需要修改 nginx 配置。

三、渲染层面

3.1 预渲染(Prerendering)

预渲染就是在构建时生成静态的 HTML,相比于单页应用需要在加载完 javascript 后再通过 js 渲染的方式,预渲染的首屏加载速度会快很多,而且 SEO 也更友好。

适用场景:内容基本静态的页面,且需要更好的用户体验和 SEO 友好。

3.2 服务端渲染(Server-Side Rendering)

服务端渲染(Server-Side Rendering,简称 SSR)是一种在服务器端将 Vue 组件渲染成HTML 字符串的技术。它在服务端拼接好 HTML字符串,然后发送给客户端,客户端无需等待下载和执行 javascript,可以直接渲染页面,这样能极大提升首屏渲染速度,SEO也更为友好。

适用场景:需要优化 SEO,对首屏性能敏感,内容安全性高,能接受服务端渲染需要的额外服务器成本。

四、用户体验

4.1 骨架屏(Skeleton Screen)

骨架屏是在内容加载前展示页面的大致结构框架,用于提升用户感知性能。

注意点:骨架屏最好是需要在打包时直接注入到 html 中,那种组件库里面的骨架屏组件的渲染太靠后了,比如 Vant 的 <van-skeleton> 组件,其效果会差很多。

4.2 懒加载

小结

本文介绍了首屏优化的一些思路和方案,主要从 网络资源请求、构建工具、渲染 和 用户体验 四方面进行优化。

回答示例(面试中怎么说)

“首屏加载慢通常是综合问题。我的思路是:先测量,再分层优化

测量时,我会用Lighthouse和Network面板看TTFB、关键文件大小和请求链。

实际优化会从几个方向入手:

网络层:启用Brotli压缩、部署CDN、升级HTTP/2。

资源层:路由懒加载、图片换WebP格式、对非首屏图片懒加载。

渲染层:内联关键CSS、用defer加载非核心JS、用preload预加载字体。

构建层:做代码分割、Tree Shaking,大库换轻量替代品。

如果项目是内容型网站,我会考虑SSR或SSG;如果是SPA,骨架屏+异步组件能有效提升感知速度。最后还要持续监控,用Performance API收集真实用户数据。”

到此这篇关于首屏加载速度慢怎么解决的文章就介绍到这了,更多相关前端首屏加载速度慢内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文