解决vite+vue3运行项目打开页面跳转很慢打不开需要刷新问题:optimized dependencies change. reloading

问题

在基于vite+vue3的大型前端项目中,经常遇到运行项目后打开本地地址跳转页面的时候页面打开很慢或者需要刷新重新编译问题,终端显示optimized dependencies change. reloading

原因

Vite在首次加载时会预构建依赖,但动态引入的组件可能未被识别,触发重新构建,导致整个应用重新加载。这通常出现在以下场景:

  1. 项目中大量使用按需导入的UI库(如Element Plus)
  2. 动态加载的第三方模块未被预构建
  3. 项目首次启动或新增依赖时未完成预构建

解决方案

在vite.config.ts文件中添加optimizeDeps预构建配置项

vite.config.ts:对element-plus组件、 'dayjs', 'ali-oss', 'js-md5'库进行依赖预构建

ts 复制代码
import fs from 'fs'
import { defineConfig } from 'vite'

const getOptimizeDepsElementPlusIncludes = () => {
  const fileNames = fs.readdirSync('node_modules/element-plus/es/components')
  const result = []

  fileNames.forEach((fileName) => {
    const styleFolderPath = `element-plus/es/components/${fileName}/style`

    if (fs.existsSync(`node_modules/${styleFolderPath}`)) {
      result.push(`${styleFolderPath}/index`)
    }
  })

  return result
}

export default defineConfig({
  optimizeDeps: {
    // 强制预构建的依赖项
    include: [...getOptimizeDepsElementPlusIncludes(), 'dayjs', 'ali-oss', 'js-md5']
  }
})

调试

因为预构建问题只会在首次运行加载出现,如果有缓存是不会出现,所以运行vite --force 强制重启应用:强制重新预构建依赖,无视缓存

js 复制代码
pnpm vite --force 
// 或者
yarn vite --force

vite.config.js 中optimizeDeps配置项理解

optimizeDeps 是 Vite 中的一个重要配置项,主要用于优化依赖预构建过程。optimizeDeps 配置主要影响开发环境(dev),对生产环境(production)没有影响。

  1. 开发环境
  • Vite 使用 optimizeDeps 进行依赖预构建
  • 目的是优化开发服务器性能和热更新体验
  • 预构建的结果存储在 node_modules/.vite 目录
  1. 生产环境
  • 使用 Rollup 进行完整的打包
  • 所有依赖都会被打包到最终的构建产物中
  • optimizeDeps 的配置在此阶段被忽略

所以,当你在调整 optimizeDeps 配置时,只需要考虑开发环境的性能优化即可,不用担心它会影响到生产环境的构建结果。

相关推荐
崔庆才丨静觅1 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60612 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了2 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅2 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅2 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅3 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment3 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅3 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊3 小时前
jwt介绍
前端
爱敲代码的小鱼3 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax