vue3监听新版本发布hooks

实现思路:通过轮询fetch跟路由获取script的hash值对比实现

新建useCheckForUpdates.ts文件

import {
  ref, onMounted, onUnmounted, Ref,
} from 'vue'

interface UseCheckForUpdatesOptions {
  url?: string
  interval?: number
}

interface UseCheckForUpdatesReturn {
  updateAvailable: Ref<boolean>
  checkForUpdates: () => void
}

export function useCheckForUpdates({
  url = '/',
  interval = 60000,
}: UseCheckForUpdatesOptions = {}): UseCheckForUpdatesReturn {
  const updateAvailable = ref(false)
  let timeoutId: number | undefined
  let previousHashes: string[] = []

  const getCurrentHashesFromHTML = async (): Promise<string[]> => {
    try {
      const response = await fetch(url)
      const htmlText = await response.text()
      const parser = new DOMParser()
      const doc = parser.parseFromString(htmlText, 'text/html')
      const scripts = Array.from(doc.scripts).filter(script => script.src)
      return scripts.map(script => {
        const hashMatch = script.src.match(/\.([a-f0-9]+)\.js/)
        return hashMatch ? hashMatch[1] : ''
      }).filter(hash => hash !== '')
    } catch (error) {
      // eslint-disable-next-line no-console
      console.error('Error fetching root HTML:', error)
      return []
    }
  }

  const scheduleNextCheck = () => {
    // eslint-disable-next-line no-use-before-define
    timeoutId = window.setTimeout(checkForUpdates, interval)
  }

  const checkForUpdates = async () => {
    const currentHashes = await getCurrentHashesFromHTML()

    if (previousHashes.length === 0) {
      previousHashes = currentHashes
      scheduleNextCheck()
      return
    }

    const hashesChanged = currentHashes.some(hash => !previousHashes.includes(hash))

    if (hashesChanged) {
      updateAvailable.value = true
    } else {
      previousHashes = currentHashes
      scheduleNextCheck()
    }
  }

  onMounted(() => {
    checkForUpdates() // Initial check
  })

  onUnmounted(() => {
    if (timeoutId) {
      clearTimeout(timeoutId)
    }
  })

  return { updateAvailable, checkForUpdates }
}

使用方法

import { useCheckForUpdates } from '~/hooks/useCheckForUpdates.ts'
const { updateAvailable } = useCheckForUpdates({
  url: '/',
  interval: 60000,
})
// 监听是否版本更新
watch(() => updateAvailable.value, async () => {
	if (updateAvailable.value) {
		console.log('版本已更新')
	}
})
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值