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

网站关键词建设网页设计能干什么

网站关键词建设,网页设计能干什么,用家庭宽带做网站,四川省建设厅注册管理中心网站首页ViteVue3实现版本更新检查,实现页面自动刷新1、使用Vite插件打包自动生成版本信息2、Vite.config.ts配置3、配置环境变量4、路由配置现有一个需求就是实现管理系统的版本发版,网页实现自动刷新页面获取最新版本 搜索了一下,轮询的方案有点浪费…

Vite+Vue3实现版本更新检查,实现页面自动刷新

      • 1、使用Vite插件打包自动生成版本信息
      • 2、Vite.config.ts配置
      • 3、配置环境变量
      • 4、路由配置

现有一个需求就是实现管理系统的版本发版,网页实现自动刷新页面获取最新版本
搜索了一下,轮询的方案有点浪费资源,不太适合我的

现在使用了路由跳转的方式去实现 这里有个大佬

就是在每次打包的时候生成一个version.json版本信息文件,在页面跳转的时候请求服务端的version.json的版本号和浏览器本地的版本号对比,进行监控版本的迭代更新,并对页面进行更新

1、使用Vite插件打包自动生成版本信息

Vite插件即是Vite虚拟模块, Vite 沿用 Rollup 的虚拟模块官网有解释(第一次了解到Vite虚拟模块)

这里的文件位置为  /src/utils/versionUpdatePlugin.ts
//简易Ts版
// versionUpdatePlugin.js
import fs from 'fs';
import path from 'path';
interface OptionVersion {version: number | string;
}
interface configObj extends Object {publicDir: string;
}const writeVersion = (versionFileName: string, content: string | NodeJS.ArrayBufferView) => {// 写入文件fs.writeFile(versionFileName, content, (err) => {if (err) throw err;});
};export default (options: OptionVersion) => {let config: configObj = { publicDir: '' };return {name: 'version-update',configResolved(resolvedConfig: configObj) {// 存储最终解析的配置config = resolvedConfig;},buildStart() {// 生成版本信息文件路径const file = config.publicDir + path.sep + 'version.json';// 这里使用编译时间作为版本信息const content = JSON.stringify({ version: options.version });if (fs.existsSync(config.publicDir)) {writeVersion(file, content);} else {fs.mkdir(config.publicDir, (err) => {if (err) throw err;writeVersion(file, content);});}},};
};

2、Vite.config.ts配置

define全局变量配置,不懂可以看看这个

import versionUpdatePlugin from './src/utils/versionUpdatePlugin'; //Rollup 的虚拟模块// 打包时获取版本信息
const CurrentTimeVersion = new Date().getTime();
const viteConfig =  defineConfig((config) => {const now = new Date().getTime()return {...define: {// 定义全局变量'process.env.VITE__APP_VERSION__': CurrentTimeVersion,},plugins: [...versionUpdatePlugin({version: CurrentTimeVersion,}),],...}})

3、配置环境变量

环境变量分开了,没有直接放在 .env中

在这里插入图片描述

//development 和 production
# 版本
VITE__APP_VERSION__ = ''

4、路由配置

路由跳转是自动检测版本,有新版本则自动更新页面

// 版本监控
const versionCheck = async () => {
//import.meta.env.MODE 获取的是开发还是生产版本的if (import.meta.env.MODE === 'development') return;const response = await axios.get('version.json');// eslint-disable-next-line no-undef//process.env.VITE__APP_VERSION__  获取环境变量设置的值,判断是否与生成的版本信息一致if (process.env.VITE__APP_VERSION__ !== response.data.version) {// eslint-disable-next-line no-undefElMessage({message: '发现新内容,自动更新中...',type: 'success',showClose: true,duration: 1500,onClose: () => {window.location.reload();},});}
};
// 这里在路由全局前置守卫中检查版本
router.beforeEach(async () => {await versionCheck()
})

继续多学习…

http://www.yayakq.cn/news/436264/

相关文章:

  • 南通网站建设方案深深圳市建设局网站
  • 广西智能网站建设企业网站设计与建设系统
  • 网站类型分析信阳百度推广
  • 如何选择一家好的网站建设公司怎么做磁力网站
  • 做设计最好的参考网站wordpress 关键词过滤
  • 网站免费维护建立网站全网营销网站建设
  • 网站模板下载后怎么用东莞企业网站建设开发公司
  • 网站开发毕设需求分析网络营销专业的就业方向
  • 盱眙网站制作深圳网站建设首选全通网络
  • 游戏网站cms网站建设需要有什么特点
  • wordpress网站模板怎么用产品设计师
  • 域名交易网站源代码下载基层建设论文查询官方网站
  • 做网站对商家的好处it运维是什么意思
  • 哪个网站是免费建站适合新手做的小生意
  • 网站建设的流程分析泰安做网站多少钱
  • 生物制药公司网站建设网络管理员是做什么的
  • 网站建设注册名有规范吗新网域名网站
  • 没有网站想做个链接页面怎么做深圳福田做网站
  • 创建手机网站个人网页设计的方法
  • 网站设计风格分析怎么为一个网站做外链
  • 广州seo建站专业团队的重要性
  • 网站建设的公司开发方案嘉兴网站建设服务
  • 哪里可以免费建网站山西城乡建设部网站首页
  • 苏州网站排名优化报价公司网站建立费用
  • 一般通过会社员山东网站seo
  • 专业做网站app的公司鑫路网站建设
  • 网站佣金怎么做会计分录wordpress social
  • 网站建设制作设计推广怎么样百度搜到自己的网站
  • 淮安市交通建设局网站阿里巴巴logo设计理念
  • 什么系统做网站好网站空间购买费用