add autoupdate
This commit is contained in:
parent
9a302d3b36
commit
4ba37b3cfe
@ -8,7 +8,7 @@ import Antd from "ant-design-vue";
|
|||||||
import "ant-design-vue/dist/reset.css";
|
import "ant-design-vue/dist/reset.css";
|
||||||
import ElementPlus from 'element-plus'
|
import ElementPlus from 'element-plus'
|
||||||
import 'element-plus/dist/index.css'
|
import 'element-plus/dist/index.css'
|
||||||
|
import './utils/auto-update'
|
||||||
async function bootstrap() {
|
async function bootstrap() {
|
||||||
const app = createApp(App)
|
const app = createApp(App)
|
||||||
setupAssets()
|
setupAssets()
|
||||||
|
60
src/utils/auto-update.js
Normal file
60
src/utils/auto-update.js
Normal file
@ -0,0 +1,60 @@
|
|||||||
|
import {ElMessage, ElMessageBox} from 'element-plus'
|
||||||
|
|
||||||
|
let lastSrcs;
|
||||||
|
|
||||||
|
const scriptReg = /\<script.*src=["'](?<src>[^"']+)/gm;
|
||||||
|
|
||||||
|
// 获取最新的 script src
|
||||||
|
async function extractNewScripts() {
|
||||||
|
const html = await fetch("/?_timestamp=" + Date.now()).then((res) =>
|
||||||
|
res.text()
|
||||||
|
);
|
||||||
|
scriptReg.lastIndex = 0;
|
||||||
|
let result = [];
|
||||||
|
let match;
|
||||||
|
while ((match = scriptReg.exec(html))) {
|
||||||
|
result.push(match.groups.src);
|
||||||
|
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
// 判断是否需要更新
|
||||||
|
async function needUpdate() {
|
||||||
|
const newScripts = await extractNewScripts();
|
||||||
|
if (!lastSrcs) {
|
||||||
|
lastSrcs = newScripts;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
let result = false;
|
||||||
|
if (newScripts.length !== lastSrcs.length) {
|
||||||
|
result = true;
|
||||||
|
} else {
|
||||||
|
for (let i = 0; i < newScripts.length; i++) {
|
||||||
|
if (newScripts[i] !== lastSrcs[i]) {
|
||||||
|
result = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
lastSrcs = newScripts;
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
// 间隔五分钟
|
||||||
|
const DURATION = 100 * 6 * 5;
|
||||||
|
function autoRefresh() {
|
||||||
|
setTimeout(async () => {
|
||||||
|
const willUpdate = await needUpdate();
|
||||||
|
if (willUpdate) {
|
||||||
|
ElMessageBox.confirm('点击确定刷新页面,取消则继续使用旧版本', '提示', {
|
||||||
|
confirmButtonText: '确定',
|
||||||
|
cancelButtonText: '取消',
|
||||||
|
type: 'warning'
|
||||||
|
}).then(async () => {
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
autoRefresh();
|
||||||
|
}, DURATION);
|
||||||
|
}
|
||||||
|
|
||||||
|
autoRefresh();
|
Loading…
Reference in New Issue
Block a user