当前位置: 首页 > news >正文

专业移动网站建设seo优化顾问服务

专业移动网站建设,seo优化顾问服务,深圳电力建设公司,窍门天下什么人做的网站前言 version-polling 是一个轻量级的 JavaScript 库,它可以实时检测 web 应用的 index.html 文件内容是否有变化。当服务端发布新版本后,前端会自动弹出更新提示,让用户刷新页面,以加载最新的资源和功能。这样可以提高用户体验和…

前言

version-polling 是一个轻量级的 JavaScript 库,它可以实时检测 web 应用的 index.html 文件内容是否有变化。当服务端发布新版本后,前端会自动弹出更新提示,让用户刷新页面,以加载最新的资源和功能。这样可以提高用户体验和数据准确性。

设计目的

为了解决后端部署之后,如何通知用户系统有新版本,并引导用户刷新页面以加载最新资源的问题。

适用场景

用户在浏览器中打开某 web 应用(通常是后台管理系统)很长时间且未刷新页面时,如果应用有新功能添加或问题修复,用户可能无法及时知道有新版发布。这样会导致用户继续使用旧版,影响用户体验和数据准确性,甚至出现程序报错。

功能特性

  1. 针对前端 web 单页应用而设计

  2. 纯前端技术实现,使用简单,不需要后端支持

  3. 支持 TypeScript

实现原理

  1. 使用 Web Worker API 在浏览器后台轮询请求页面,不会影响主线程运行。

  2. 命中协商缓存,对比本地和服务器请求响应头etag字段值。

  3. 如果etag值不一致,说明有更新,则弹出更新提示,并引导用户手动刷新页面(例如弹窗提示),完成应用更新。

  4. 当页面不可见时(例如切换标签页或最小化窗口),停止实时检测任务;再次可见时(例如切换回标签页或还原窗口),恢复实时检测任务。

浏览器兼容性

适用于支持原生 ES 模块的现代浏览器,具体可参考以下 browserslist 配置

defaults and supports es6-module
maintained node versions

安装

# 本地项目安装
npm install version-polling --save

使用

  1. 通过 npm 引入,并通过构建工具进行打包

// 在应用入口文件中使用: 如 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('有新版本,请刷新页面');},
});
  1. 通过 script 引入,直接插入到 HTML,无侵入用法,接入成本最低

<!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

注意事项

  • version-polling 需要在支持 web worker 和 fetchAPI 的浏览器中运行,不支持 IE 浏览器

  • version-polling 需要在 web 应用的入口文件(通常是 index.html)中引入,否则无法检测到更新

  • version-polling 需要在 web 应用的服务端配置协商缓存,否则无法命中缓存,会增加网络请求

  • version-polling 需要在 web 应用的服务端保证每次发版后,index.html 文件的 etag 字段值会改变,否则无法检测到更新

http://www.ds6.com.cn/news/27170.html

相关文章:

  • 安徽国贸网站建设网店推广策划书
  • 学做日本菜的网站好百度视频排名优化
  • xmapp怎样做网站怎么查询最新网站
  • 做调查的网站知乎合肥网络seo推广服务
  • 网站怎么做不违法西安疫情最新消息1小时内
  • 广州网站设计总部网站seo优化多少钱
  • 个人不允许建网站网络营销推广方式包括哪几种
  • 化工销售怎么做网站成都私人做网站建设
  • 深圳实惠的专业建站公司html网页制作代码大全
  • 社交网站 cms推荐友情链接
  • 域名访问网站怎么下载推广的几种方式
  • 美食网站开发目的快手seo软件下载
  • 网站建设完工后在什么科目核算百度舆情监测平台
  • 怎样做网站吸引客户短视频seo推广隐迅推专业
  • 做动画的动作库网站谷歌网站
  • 英文网站建设 济南全面的seo网站优化排名
  • 网站收录很高百度贴吧官网app下载
  • 做快递单的网站会不会是骗人的友情链接也称为
  • 网站常用英文站长工具是干嘛的
  • qq空间如何做微网站百度首页广告
  • 国外创意设计网站网站建设知名公司
  • 网页设计怎么做网站今日百度搜索风云榜
  • 阿里云做网站官网企业网站的域名是该企业的
  • 网站开发九大优势百度网址大全免费下载
  • 浙江质监站网址搜索引擎营销名词解释
  • 手机网站可以做动态吗营销网站建设教学
  • 没有独立网站淘宝客推广怎么做成都百度推广账户优化
  • 阜宁专业做网站的公司英国搜索引擎
  • 如何阿里巴巴网站做推广买卖友链
  • 模版用iis在自己家电脑上做网站百度平台订单查询