App.vue 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <script setup>
  2. import { RouterView } from 'vue-router'
  3. import { ref, onMounted, onUnmounted, nextTick } from 'vue'
  4. import Confirm from '@/plugins/confirm'
  5. import axios from 'axios'
  6. import { vue_version } from './version.js'
  7. import { useSystem } from '@/store/system'
  8. const { setBeijingTimestamp } = useSystem()
  9. const timer = ref(null)
  10. // const setFn = ref()
  11. const setIntervalTime = 3000 // 接口调用间隔时间
  12. function open () {
  13. if (timer.value) clearInterval(timer.value)
  14. timer.value = setInterval(() => { checkVersion() }, setIntervalTime)
  15. }
  16. onMounted(() => {
  17. nextTick(() => {
  18. const process_ENV = import.meta.env.VITE_USER_NODE_ENV || ''
  19. if (process_ENV === 'production') {
  20. open()
  21. }
  22. })
  23. })
  24. onUnmounted(() => {
  25. if (timer.value) clearInterval(timer.value)
  26. })
  27. // window.location.reload() // 方法会根据缓存的有效期和修改时间,决定是否重新从服务器下载内容。如果缓存的内容没有过期或没有修改,就会直接使用缓存,这样可以节省流量和时间
  28. // window.location.reload(true) // true参数会忽略缓存的内容,强制重新从服务器下载所有内容.包括 JavaScript 文件,图像,文本文件等。这样可以保证显示网页的最新内容,但是会消耗更多的流量和时间。
  29. // window.location.replace(window.location.href) // 方法会把浏览器中的临时文件夹的文件删除再重新从服务器下载。这样可以清除一些可能造成问题的缓存文件,但是也会消耗更多的流量和时间。
  30. let ConfirmDone = false
  31. // 检查版本号
  32. const checkVersion = () => {
  33. const baseUrl = import.meta.env.VITE_BASE_URL || ''
  34. // const env_v = import.meta.env?.VITE_VERSION || ''
  35. const tenantId = import.meta.env?.VITE_TENANTCODE || ''
  36. const get_v = localStorage.getItem('RES_VERSION') || ''
  37. //
  38. if (!baseUrl || !vue_version || !tenantId) return
  39. axios.get(`${baseUrl}/app-api/menduner/system/get/version`, {
  40. headers: { ['tenant-id']: tenantId },
  41. cache: 'no-store' // 禁用缓存
  42. }).then(({ data }) => {
  43. const { version, time } = data?.data
  44. setBeijingTimestamp(time)
  45. if (!version || version === vue_version ) { // 接口报错和版本一致不弹Confirm
  46. return
  47. }
  48. if (ConfirmDone) {
  49. return
  50. }
  51. if (version === get_v && version !== vue_version) { // reload(true)刷新不成功,清除缓存刷新
  52. localStorage.clear()
  53. window.location.replace(window.location.href)
  54. return
  55. }
  56. ConfirmDone = true // 后续不弹Confirm
  57. Confirm('系统提示', '发现新版本,将立即刷新页面', { hideCancelBtn: true }).then(() => {
  58. localStorage.setItem('RES_VERSION', version)
  59. window.location.reload(true)
  60. })
  61. }).catch(err => {
  62. console.log('checkVersion-err', err)
  63. })
  64. }
  65. </script>
  66. <template>
  67. <v-app>
  68. <RouterView />
  69. </v-app>
  70. </template>
  71. <style scoped>
  72. </style>