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知识来解决的,欢迎在评论区留言,给看到这篇文章的同行一个解决思路

相关推荐
晓得迷路了17 小时前
栗子前端技术周刊第 121 期 - Vitest 4.1、Nuxt 4.4、Next.js 16.2...
前端·javascript·vite
朱建伟2 天前
大神尤雨溪再次出手,前端工具链整合--该文章是对vite plus官方README文档进行了翻译
前端·vite
阿帕琪尔2 天前
😎vite插件: 自动打包压缩图片和转webp(二)
前端·vite
踩着两条虫2 天前
AI 驱动的 Vue3 应用开发平台 深入探究(十九):CLI与工具链之Create VTJ CLI 参考
前端·ai编程·vite
ん贤4 天前
首屏优化实践:如何将 Vue3 + Vite 项目的加载速度提升3倍
性能优化·vue·vite
VaJoy4 天前
给到夯!前端工具链新标杆 Vite Plus 初探
前端·vite
Lsx-codeShare5 天前
前端发版后页面白屏?一套解决用户停留旧页面问题的完整方案
前端·javascript·前端框架·vue·vite
CharlieWang6 天前
Vite 终于有了一个很轻的服务端搭档
前端·vite·mcp
Selicens6 天前
turbo迁移vite+(vite-plus)实践
前端·javascript·vite