vite项目保存代码后不刷新页面 vite热更新

vite项目保存代码后不刷新页面 vite热更新

问题场景

接手了一个新项目,发现修改代码后,控制台显示hmr更新了文件,但本地运行的项目不会自动刷新页面,每次都要手动刷新。

scss 复制代码
 [vite] (client) hmr update /src/views/Home.vue, /src/views/Home.vue?vue&type=style&index=0&scoped=2dc54a20&lang.scss  

解决办法

我尝试了很多办法,也试过更新vite版本,均未解决。过程中发现在修改vite.config.ts文件时,页面能自动刷新,然后就想到写一个脚本,监听项目文件的改动, 如果文件有改动,就自动更新下vite.config.ts文件,从而达到刷新页面的效果。

这是我的脚本文件,使用前,需要下载一个插件

复制代码
npm install chokidar -D

监听脚本

  1. 在你的项目跟目录下创建一个scripts/force-refresh.js文件,粘贴以下代码
javascript 复制代码
import fs from 'fs';
import path from 'path';
import chokidar from 'chokidar';

const root = process.cwd();
const viteConfigPath = path.resolve(root, 'vite.config.ts');
console.log(
  `开始监听 ${path.join(root, 'src')}目录下文件是否有改动,改动时将更新 vite.config.ts 以达到刷新页面的效果`,
);

// --- watcher 配置 ---
const watcher = chokidar.watch([path.join(root, 'src')], {
  usePolling: true,
  ignoreInitial: true,
});

let isWriting = false;
let lastUpdated = 0;
const MIN_INTERVAL_MS = 1000;

watcher.on('all', (event, filePath) => {
  console.log(`改动文件: ${event} ${filePath}`);
  if (filePath.includes('vite.config.ts')) return;
  const now = Date.now();
  if (isWriting || now - lastUpdated < MIN_INTERVAL_MS) return;
  triggerUpdate();
});

function triggerUpdate() {
  try {
    const timestamp = new Date().toISOString();
    const text = fs.readFileSync(viteConfigPath, 'utf8');
    const updated = text.replace(
      /\/\/\s*AUTO_REFRESH_MARKER:.*/i,
      `// AUTO_REFRESH_MARKER: ${timestamp}`,
    );
    fs.writeFileSync(viteConfigPath, updated, 'utf8');
    lastUpdated = Date.now();
  } catch (e) {
    console.error(`[force-refresh] ❌ Error updating vite.config.ts`, e);
  }
}
  1. 修改package.json,添加一个启动命令
json 复制代码
"dev": "vite",
 "dev-watch": "start /B vite && node scripts/force-refresh.js",

dev是原本有的命令, dev-watch是我们添加的命令, 注意你的force-refresh.js是否放在scripts文件夹下。

拓展

针对这个脚本,你可以自定义要监听的文件目录,文件类型,做到精准监听,具体的自由实现。 邪修办法!!! 有遇到同样问题,查到了原因,真正通过vite知识来解决的,欢迎在评论区留言,给看到这篇文章的同行一个解决思路

相关推荐
weixin_425543734 天前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
敲敲了个代码6 天前
从N倍人力到1次修改:Vite Plugin Modular 如何拯救多产品前端维护困境
前端·javascript·面试·职场和发展·typescript·vite
打小就很皮...7 天前
React 19 + Vite 6 + SWC 构建优化实践
前端·react.js·vite·swc
xiaoxue..11 天前
全栈项目 学习日记 (第一章)
前端·react.js·面试·vite
wuhen_n17 天前
Webpack vs Vite:前端构建工具对比
前端·webpack·node.js·vite
zhengxianyi51523 天前
vite build 发布到nginx二级目录——将yudao-ui-go-view打包、部署到big目录下
vue.js·nginx·vite·前后端分离·打包·ruoyi-vue-pro优化·部署运维
Mast Sail23 天前
WebStrom+Vitesse+Vue3项目路径报错爆红问题
vue·vite·webstorm
华玥作者24 天前
uni-app + Vite 项目中使用 @uni-helper/vite-plugin-uni-pages 实现自动路由配置(超详细)
前端·uni-app·vue·vue3·vite
coderjc1 个月前
依赖预构建
vite
实习生小黄1 个月前
vue3静态文件打包404解决方案
前端·vue.js·vite