这是一个适用于前端版本检测能力的插件。
仅包含客户端检测程序,不包含构建时的插件,如vite、webpack等
npm i web-check-version -S
yarn add web-check-version
pnpm add web-check-version
import webVersionCheck from "web-check-version";
webVersionCheck({
filePath: "version.json", // 需要请求的版本文件地址,默认是不需要更改的,如果部署的网址为域名的二级目录,请填写绝对路径。
interval: 5 * 1000,
key: "version", // 版本文件json中的version key
// 检测到版本更新时的回调
update(reload, { version }) {
const confirm = window.confirm(`
"发现新版本,是否刷新"
"最新版本号为:", ${version}
`);
if (confirm) {
reload?.();
}
},
debug: false, //是否开启debug模式, debug模式下,update回调时机与实际相反。主要用于测试
});
vite:
推荐使用 vite-plugin-generate-file
pnpm add -D vite-plugin-generate-file
vite.config.js
import { defineConfig } from "vite";
import generateFile from "vite-plugin-generate-file";
// https://vitejs.dev/config/
export default defineConfig({
server: {
port: 8000, //
},
plugins: [
generateFile([
// version.json 标识当前版本信息,用于页面更新提醒
{
type: "json",
output: "version.json",
data: {
version: Date.now(),
},
},
]),
],
});
webpack:
暂时没找到合适的插件,待补充