哈喽,大家好 我是
xy
👨🏻💻。今天给大家分享一个用于实时检测web
应用更新的JavaScript
库:version-polling
!!!
version-polling
是一个轻量级的 JavaScript
库,它可以实时检测 web
应用的 index.html
文件内容是否有变化。当服务端发布新版本后,前端会自动弹出更新提示,让用户刷新页面,以加载最新的资源和功能。这样可以提高用户体验和数据准确性。
为了解决后端部署之后,如何通知用户系统有新版本,并引导用户刷新页面以加载最新资源的问题。
用户在浏览器中打开某 web
应用(通常是后台管理系统)很长时间且未刷新页面时,如果应用有新功能添加或问题修复,用户可能无法及时知道有新版发布。这样会导致用户继续使用旧版,影响用户体验和数据准确性,甚至出现程序报错。
web
单页应用而设计TypeScript
Web Worker
API 在浏览器后台轮询请求页面,不会影响主线程运行。etag
字段值。etag
值不一致,说明有更新,则弹出更新提示,并引导用户手动刷新页面(例如弹窗提示),完成应用更新。适用于支持原生 ES 模块的现代浏览器,具体可参考以下 browserslist 配置
defaults and supports es6-module
maintained node versions
# 本地项目安装
npm install version-polling --save
// 在应用入口文件中使用: 如 main.js, app.jsx
import { createVersionPolling } from "version-polling";
createVersionPolling({
appETagKey: "__APP_ETAG__",
pollingInterval: 5 * 1000, // 单位为毫秒
silent: process.env.NODE_ENV === "development", // 开发环境下不检测
onUpdate: (self) => {
// 当检测到有新版本时,执行的回调函数,可以在这里提示用户刷新页面
const result = confirm("页面有更新,点击确定刷新页面!");
if (result) {
self.onRefresh();
} else {
self.onCancel();
}
// 强制更新可以用alert
// alert('有新版本,请刷新页面');
},
});
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>前端页面自动检测更新-示例</title>
</head>
<body>
<script src="//unpkg.com/version-polling/dist/version-polling.min.js"></script>
<script>
VersionPolling.createVersionPolling({
appETagKey: "__APP_ETAG__",
pollingInterval: 5 * 1000,
onUpdate: (self) => {
// 当检测到有新版本时,执行的回调函数,可以在这里提示用户刷新页面
const result = confirm("页面有更新,点击确定刷新页面!");
if (result) {
self.onRefresh();
} else {
self.onCancel();
}
},
});
</script>
</body>
</html>
在项目 index.html 下直接插入 script,类似于百度统计那种用法,具体代码参考:
https://github.com/JoeshuTT/version-polling
web worker
和 fetchAPI
的浏览器中运行,不支持 IE 浏览器index.html
)中引入,否则无法检测到更新协商缓存
,否则无法命中缓存,会增加网络请求index.html
文件的 etag
字段值会改变,否则无法检测到更新
公众号
:前端开发爱好者
专注分享web
前端相关技术文章
、视频教程
资源、热点资讯等,如果喜欢我的分享,给 🐟🐟 点一个赞
👍 或者 ➕关注
都是对我最大的支持。
欢迎长按图片加好友
,我会第一时间和你分享前端行业趋势
,面试资源
,学习途径
等等。
添加好友备注【进阶学习】拉你进技术交流群
关注公众号后,在首页:
面试题
,获取最新大厂面试资料。简历
,获取 3200 套 简历模板。React实战
,获取 React 最新实战教程。Vue实战
,获取 Vue 最新实战教程。ts
,获取 TypeScript 精讲课程。vite
,获取 Vite 精讲课程。uniapp
,获取 uniapp 精讲课程。js书籍
,获取 js 进阶 必看书籍。Node
,获取 Nodejs+koa2 实战教程。数据结构算法
,获取数据结构算法教程。架构师
,获取 架构师学习资源教程。关注获取