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

vue+electron 自動更新的實現(xiàn)代碼

 更新時間:2024年02月27日 15:16:46   作者:擺爛程序魚  
這篇文章主要介紹了vue+electron 自動更新的實現(xiàn)代碼,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧

1. 配置 package.json或vue.config.js文件中的應用更新服務器地址

module.exports = {
  pluginOptions: {
    electronBuilder: {
        ...
        publish: [
          {
            provider: 'generic',
            url: 'http://qc***/***'  // 服務器地址
          }
        ]
        ...
      }
    }
  }
}
 

2. 在主進程寫更新應用邏輯

在 checkupdate.js 文件或 main.js 中寫入

import { autoUpdater } from 'electron-updater'
const { build } = require("../../../package.json")
const { app, dialog } = require('electron');
const path = require("path");
import { ipcRenderer } from "electron";
const websocket = require('ws')
//跳過打包檢查  開發(fā)環(huán)境使用  打包的時候注釋掉
// Object.defineProperty(app, 'isPackaged', {
// 	get() {
// 		return true;
// 	}
// });
/**
 * -1 檢查更新失敗 0 正在檢查更新 1 檢測到新版本,準備下載 2 未檢測到新版本 3 下載中 4 下載完成
 **/
class Update {
    mainWindow
    constructor() {
        autoUpdater.setFeedURL(build.publish[0].url)
        // 當更新發(fā)生錯誤的時候觸發(fā)。
        autoUpdater.on('error', (err) => {
            if (err.message.includes('sha512 checksum mismatch')) {
                this.Message(this.mainWindow, -1, 'sha512校驗失敗')
            } else {
                this.Message(this.mainWindow, -1, '錯誤信息請看主進程控制臺')
            }
        })
        // 當開始檢查更新的時候觸發(fā)
        autoUpdater.on('checking-for-update', (event, arg) => {
            this.timer(this.mainWindow, 0, "正在檢查更新...", 5000)
        })
        // 發(fā)現(xiàn)可更新數(shù)據(jù)時
        autoUpdater.on('update-available', (event, arg) => {
            this.timer(this.mainWindow, 1, "發(fā)現(xiàn)新版本", 10000)
            this.timer(this.mainWindow, 1, "檢測到新版本,正在下載安裝包...", 15000)
        })
        // 沒有可更新數(shù)據(jù)時
        autoUpdater.on('update-not-available', (event, arg) => {
            this.timer(this.mainWindow, 2, "暫未檢測到新版本,當前版本為最新版本,無需更新", 15000)
        })
        // 下載監(jiān)聽  
        autoUpdater.on('download-progress', (progressObj) => {
            // {
            //   total: 1145589126,
            //   delta: 71139212,
            //   transferred: 71139212,
            //   percent: 6.209836527376395,
            //   bytesPerSecond: 69881348
            // }
            let total = this.renderSize(progressObj.total); //總大小
            let percent = parseFloat(progressObj.percent.toFixed(2)); //下載進度
            let bytesPerSecond = this.renderSize(progressObj.bytesPerSecond); //下載速度
            // let message = `總大?。?{total} 下載進度:${percent}% 下載速度${bytesPerSecond}/S`
            let message = `總大?。?{total} 下載進度:${percent}%`
            // this.Message(this.mainWindow, 3, message)
        })
        // 下載完成
        autoUpdater.on('update-downloaded', () => {
            // console.log('done')
            this.Message(this.mainWindow, 4, "新版本已下載完成,五秒后自動安裝并重啟...")
            setTimeout(() => {
                this.quitInstall();
            }, 5000)
        })
    }
    // 負責向渲染進程發(fā)送信息
    Message(mainWindow, type, data) {
        const senddata = {
            state: type,
            msg: data || ''
        }
        let journalSocket = new websocket("ws://localhost:16478");
        // mainWindow.webContents.send('update-msg', senddata)
        journalSocket.on("open", function () {
            journalSocket.send(data);
        });
    }
    // 執(zhí)行自動更新檢查
    checkUpdate(mainWindow) {
        this.mainWindow = mainWindow
        autoUpdater.updateConfigPath = path.resolve(__static, 'default-app-update.yml')
        // this.Message(this.mainWindow, 4, path.resolve(__static, 'default-app-update.yml'))
        // autoUpdater.currentVersion = "0.0.1";//調(diào)試使用 正式上線后注釋掉
        autoUpdater.checkForUpdates().catch(err => {
            console.log('網(wǎng)絡連接問題', err)
        })
    }
    // 退出并安裝
    quitInstall() {
        autoUpdater.quitAndInstall()
    }
    // 處理文件大小格式化
    renderSize(value) {
        if (null == value || value == '') {
            return "0 Bytes";
        }
        var unitArr = new Array("Bytes", "KB", "MB", "GB", "TB", "PB", "EB", "ZB", "YB");
        var index = 0;
        var srcsize = parseFloat(value);
        index = Math.floor(Math.log(srcsize) / Math.log(1024));
        var size = srcsize / Math.pow(1024, index);
        size = size.toFixed(2);//保留的小數(shù)位數(shù)
        return size + unitArr[index];
    }
    // 定時器
    timer(mainWindow, number, message, time) {
        setTimeout(() => {
            this.Message(mainWindow, number, message)
        }, time)
    }
}
export default Update

3. 打包升級版的應用(v1.1.0)

注意:

每次打包記得去package.json文件中修改version版本號,這樣系統(tǒng)才會檢測到最新版本

打包后 dis有如下兩個文件:

新版本安裝包.exe
latest.yml

將上面兩個文件復制到 ‘更新服務器’ (http://qc***/***) 目錄下;

以后每次有更新就復制這兩個文件至 ‘更新服務器’,舊版本的應用的執(zhí)行文件(.exe)可以刪除。

到此這篇關于vue+electron 自動更新的文章就介紹到這了,更多相關vue electron 自動更新內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Vue實現(xiàn)購物車基本功能

    Vue實現(xiàn)購物車基本功能

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)購物車的基本功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Vue 計數(shù)器的實現(xiàn)

    Vue 計數(shù)器的實現(xiàn)

    這篇文章主要介紹了Vue 計數(shù)器的實現(xiàn),主要利用HTML實現(xiàn)步驟現(xiàn)在頁面上簡單實現(xiàn)一個計數(shù)器,內(nèi)容簡單且詳細,需要的朋友可以參考一下
    2021-10-10
  • Vue3+Element+Ts實現(xiàn)表單的基礎搜索重置等功能

    Vue3+Element+Ts實現(xiàn)表單的基礎搜索重置等功能

    本文主要介紹了Vue3+Element+Ts實現(xiàn)表單的基礎搜索重置等功能,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • vue實現(xiàn)頭像上傳功能

    vue實現(xiàn)頭像上傳功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)頭像上傳功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • vue項目input標簽checkbox,change和click綁定事件的區(qū)別說明

    vue項目input標簽checkbox,change和click綁定事件的區(qū)別說明

    這篇文章主要介紹了vue項目input標簽checkbox,change和click綁定事件的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue如何使用el-table遍歷循環(huán)表頭和表體數(shù)據(jù)

    vue如何使用el-table遍歷循環(huán)表頭和表體數(shù)據(jù)

    這篇文章主要介紹了vue如何使用el-table遍歷循環(huán)表頭和表體數(shù)據(jù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue.js基礎知識匯總

    Vue.js基礎知識匯總

    Vue.js 專注于 MVVM 模型的 ViewModel 層。它通過雙向數(shù)據(jù)綁定把 View 層和 Model 層連接了起來。Vue.js和其他庫相比是一個小而美的庫,作者的主要目的是通過一個盡量簡單的 API 產(chǎn)生可反映的數(shù)據(jù)綁定和可組合的視圖組件,感覺作者的思路非常清晰。
    2016-04-04
  • Vue3路由進階實戰(zhàn)教程之參數(shù)傳遞與導航守衛(wèi)核心技術

    Vue3路由進階實戰(zhàn)教程之參數(shù)傳遞與導航守衛(wèi)核心技術

    本文介紹了路由參數(shù)傳遞的進階應用技巧,包括路由配置與參數(shù)驗證、組件參數(shù)接收、查詢參數(shù)傳遞、導航守衛(wèi)以及性能優(yōu)化與最佳實踐,感興趣的朋友一起看看吧
    2025-03-03
  • 解決el-select數(shù)據(jù)量過大的3種方案

    解決el-select數(shù)據(jù)量過大的3種方案

    最近做完一個小的后臺管理系統(tǒng),快上線了,發(fā)現(xiàn)一個問題,有2個select的選項框線上的數(shù)據(jù)量是1w+,而測試環(huán)境都是幾百的,所以導致頁面直接卡住了,本文給大家總結(jié)了3種方法,需要的朋友可以參考下
    2023-09-09
  • webstorm添加*.vue文件支持

    webstorm添加*.vue文件支持

    這篇文章主要介紹了webstorm添加*.vue文件支持,webstorm很多的插件內(nèi)置,不用安裝插件,下面嘗試用vue和es6做項目,有興趣的可以了解一下
    2018-05-05

最新評論