欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

VUE項(xiàng)目自動(dòng)檢測服務(wù)端是否發(fā)布了新版本

 更新時(shí)間:2025年01月02日 10:03:00   作者:Asurplus  
本文主要介紹了VUE項(xiàng)目自動(dòng)檢測服務(wù)端是否發(fā)布了新版本,通過輪詢方式檢測Vue項(xiàng)目新版本并提示用戶刷新頁面,具有一定的參考價(jià)值,感興趣的可以了解一下

今天介紹的是通過輪詢的方式去檢測服務(wù)端是否發(fā)布了新版本,從而提醒客戶刷新頁面,提升用戶體驗(yàn)。

1、實(shí)現(xiàn)思路

  • 使用輪詢的方式獲取項(xiàng)目中 index.html 文件。
  • 查詢文件引入的 JS 文件是否有更新( Vue 每次打包后會(huì)生成新的引入文件,如 login.513ef76d.js)。
  • 對比新舊文件,如果有不同,則說明服務(wù)器中的項(xiàng)目文件已經(jīng)更新,需要提示用戶刷新頁面以獲取最新的項(xiàng)目資源。

2、實(shí)現(xiàn)步驟

在 src 目錄下新建一個(gè) auto-update.js 文件,內(nèi)容為:

let lastSrc;

// 匹配 Script 標(biāo)簽中的 src
const scriptReg = /\<script.*src=["'](?<src>[^"']+)/gm;

/**
 * 提取服務(wù)器的 Script 標(biāo)簽中的 src
 */
async function extractNewScripts() {
    const html = await fetch('/?_timestamp=' + Date.now()).then(resp => {
        return resp.text()
    })
    scriptReg.lastIndex = 0
    let result = []
    let match;
    while ((match = scriptReg.exec(html))) {
        result.push(match.groups.src)
    }
    return result
}

/**
 * 判斷是否有新版本
 */
async function hasNewVersion() {
    const newScripts = await extractNewScripts()
    if (!lastSrc) {
        lastSrc = newScripts
        return false
    }
    let result = false
    if (lastSrc.length !== newScripts.length) {
        result = true
    }
    for (let i = 0; i < lastSrc.length; i++) {
        if (lastSrc[i] !== newScripts[i]) {
            result = true
            break
        }
    }
    lastSrc = newScripts
    return result
}

/**
 * 自動(dòng)更新定時(shí)器
 */
function autoRefresh() {
    setTimeout(async () => {
        const needUpdate = await hasNewVersion()
        if (needUpdate) {
            const result = confirm('項(xiàng)目發(fā)布新版本,立即更新?')
            if (result) {
                location.reload()
            }
        }
        autoRefresh()
    }, 5000)
}

autoRefresh()

在 main.js 文件中引入 auto-update.js 文件即可

import './auto-update'

3、測試

將項(xiàng)目打包發(fā)布,瀏覽器訪問項(xiàng)目

在這里插入圖片描述

改變項(xiàng)目中的頁面內(nèi)容,重新打包發(fā)布

在這里插入圖片描述

點(diǎn)擊 “確定” 之后,頁面就會(huì)自動(dòng)刷新了

到此這篇關(guān)于VUE項(xiàng)目自動(dòng)檢測服務(wù)端是否發(fā)布了新版本的文章就介紹到這了,更多相關(guān)VUE 自動(dòng)檢測服務(wù)端新版本內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論