Vue3 + vite 首屏优化加载速度

1.使用路由懒加载(异步加载)

当访问到当前页面,再去加载

javascript 复制代码
// router/index.ts
import { createRouter, createWebHistory } from 'vue-router'

const routes = [
  {
    path: '/',
    component: () => import('@/views/Home.vue') // ✅ 异步加载
  },
  {
    path: '/about',
    component: () => import('@/views/About.vue')
  }
]

const router = createRouter({
  history: createWebHistory(),
  routes
})

export default router

这样只打包当前访问的组件,首屏包更小,速度更快。

2.使用defineAsyncComponent异步加载组件

javascript 复制代码
import { defineAsyncComponent } from 'vue'

const LazyChart = defineAsyncComponent(() => import('./Chart.vue'))

可用于图表、地图、大型列表、富文本编辑器等组件

3.压缩静态资源(gzip / brotli)

复制代码
npm install vite-plugin-compression -D
javascript 复制代码
// vite.config.ts
import compression from 'vite-plugin-compression'

export default {
  plugins: [
    compression({
      algorithm: 'gzip', // 或 brotliCompress
      ext: '.gz'
    })
  ]
}

可以把 JS/CSS 从几百 KB 压缩到几十 KB,浏览器自动解压

4. 使用 SSR(服务端渲染)或 SSG(预渲染)

对于 SEO 要求高或首屏复杂的页面,可以用:

  • SSR:服务端渲染,推荐使用 Nuxtvite-plugin-ssr
  • SSG:预渲染 HTML 页面,使用 vite-plugin-prerender
css 复制代码
npm i vite-plugin-prerender -D

5. 图片优化与懒加载

1)压缩图片,使用 webp 格式

2)大图懒加载:

xml 复制代码
<img v-lazy="url" /> <!-- 使用 vue-lazyload 插件 -->

或手动:

ini 复制代码
<img :src="show ? url : placeholder" @load="onLoad" />

6. 移除不必要的依赖和 console

arduino 复制代码
// vite.config.ts
export default {
  esbuild: {
    drop: ['console', 'debugger']
  }
}

7. 开启浏览器缓存 + CDN 提升加载速度

markdown 复制代码
-   把打包文件缓存加 hash(Vite 默认有)

-   使用 CDN 托管 `index.html`、图片、JS 包等静态资源

8. 预加载关键资源

使用 <link rel="preload"> 优先加载关键 JS/CSS

ini 复制代码
<link rel="preload" href="/src/main.js" as="script">

9. 骨架屏优化感知性能

使用骨架屏在加载时替代内容,提升"感知速度"

ini 复制代码
<Skeleton v-if="loading" />
<RealContent v-else />

10. 分析构建包体积

sql 复制代码
npm install rollup-plugin-visualizer -D
javascript 复制代码
// vite.config.ts
import { visualizer } from 'rollup-plugin-visualizer'

export default {
  plugins: [visualizer()]
}

然后运行 vite build → 查看打包中哪些包太大可优化

相关推荐
0思必得017 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东51618 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino18 小时前
图片、文件的预览
前端·javascript
layman052820 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔20 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李20 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN20 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒20 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库20 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_1800790524720 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫