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 → 查看打包中哪些包太大可优化

相关推荐
一条小鲨鱼几秒前
所遇到的响应式问题
前端·vue.js
M ? A2 分钟前
你的 Vue 路由,VuReact 会编译成什么样的 React 路由?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
L.Cheng4 分钟前
谷歌浏览器如何禁用自动更新_Chrome关闭后台升级程序
前端·chrome
donecoding10 分钟前
类型与语法的“直觉对齐”:TS 切入的 Go 语言初体验
前端·typescript·go
web守墓人11 分钟前
【linux】Mubuntu v1.0.7发布:支持codex cli完整运行
前端·codex
WYiQIU11 分钟前
宇树科技Web前端岗(AI方向),这不算泄题吧......
前端·vue.js·人工智能·笔记·科技·面试·职场和发展
Januea11 分钟前
Chrome的Fetch/XHR是什么?
前端·chrome
betazhou13 分钟前
TDSQL-PG创建测试表并定时插入数据模拟生产
前端·javascript·数据库·tdsql·tdsql-pg
W.A委员会21 分钟前
地址栏输入url到显示画面
前端·网络
xuankuxiaoyao23 分钟前
Vue.js实践-组件基础上
前端·javascript·vue.js