electron-vue?項(xiàng)目添加啟動(dòng)loading動(dòng)畫的實(shí)現(xiàn)思路

前言
electron-vue腳手架搭建的項(xiàng)目,在開發(fā)階段可能你注意不到項(xiàng)目啟動(dòng)慢的問題,但是在build 生成的exe可執(zhí)行文件,啟動(dòng)后,要反應(yīng)很久才能進(jìn)入到app.vue 中加載的頁面,體驗(yàn)性很差。
正文
針對(duì)上訴問題,產(chǎn)生的原因是在渲染進(jìn)程加載vue的時(shí)候,特別慢,為了提高用戶體驗(yàn),我們的項(xiàng)目可以在啟動(dòng)的時(shí)候添加一個(gè)loading動(dòng)畫,然后再進(jìn)入app.vue的頁面。
實(shí)現(xiàn)思路
我們可以通過一個(gè)單獨(dú)的啟動(dòng)窗口來創(chuàng)建loading頁面,在項(xiàng)目中其他準(zhǔn)備工作未完成時(shí)出現(xiàn)在用戶的視野中給用戶一定的反饋,等準(zhǔn)備工作完成后,通過渲染進(jìn)程向主進(jìn)程發(fā)送準(zhǔn)備完畢的消息,關(guān)閉啟動(dòng)窗口即可。
?。?)設(shè)置啟動(dòng)頁面
loading動(dòng)畫可以寫在一個(gè)單獨(dú)的html頁面,屬于靜態(tài)資源,electron-vue 官網(wǎng)推薦,把靜態(tài)資源存放在 /static 目錄下即可,創(chuàng)建loading.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
body{
margin: 0;
padding: 0;
overflow: hidden;
background:rgba(0,0,0,.5)
}
body::-webkit-scrollbar{
display: none;
img{
width: 200px;
height: 200px;
</style>
</head>
<body>
<img src="./_.gif" alt="" srcset="">
</body>
</html>(2)修改主進(jìn)程的index.js ,如下:
import { app, BrowserWindow, ipcMain } from "electron";
import "../renderer/store";
if (process.env.NODE_ENV !== "development") {
global.__static = require("path")
.join(__dirname, "/static")
.replace(/\\/g, "\\\\");
}
let mainWindow, loadingWindow;
const winURL =
process.env.NODE_ENV === "development"
? `http://localhost:9080`
: `file://${__dirname}/index.html`;
const loadingURL =
process.env.NODE_ENV === "development" //加載loading.html頁面地址
? require("path").join(__static, "loading.html")
: `file://${__static}/loading.html`;
const showLoading = (cb) => {
loadingWindow = new BrowserWindow({
show: false,
frame: false, // 無邊框(窗口、工具欄等),只包含網(wǎng)頁內(nèi)容
width: 200,
height: 200,
resizable: false,
transparent: true, // 窗口是否支持透明,如果想做高級(jí)效果最好為true
});
loadingWindow.once("show", cb);
loadingWindow.loadURL(loadingURL);
loadingWindow.show();
};
const createWindow = () => {
mainWindow = new BrowserWindow({
webPreferences: {
nativeWindowOpen: true,
title: "主窗口",
},
height: 563,
width: 1000,
useContentSize: true,
fullscreen: true, // 是否全屏
frame: false, //是否顯示窗口邊框
backgroundColor: "#000000", //設(shè)置背景顏色
mainWindow.loadURL(winURL);
mainWindow.once("ready-to-show", () => {
loadingWindow.hide();
loadingWindow.close();
mainWindow.show();
app.on("ready", () => {
showLoading(createWindow);
});上面的代碼中,app在監(jiān)聽到ready事件時(shí),執(zhí)行showLoading方法,傳入了createWindow 方法為參數(shù),首先創(chuàng)建loadinWindow窗口,然后注冊(cè)show事件,loading窗口加載了loading.html 頁面后,去加載mainWindow窗口,改窗口加載了頁面app.vue(即index.html)內(nèi)容,并注冊(cè)了 " ready-to-show "事件,改事件用于關(guān)閉loading窗口,顯示mainWindow窗口。
注意:electron-vue 提供了一個(gè)名為__static的全局變量,它將產(chǎn)生一個(gè)指向static/目錄的正確路徑。
?。?)在app.vue中調(diào)用 " ready-to-show " 事件
<template>
<div id="app">
<router-view></router-view>
</div>
</template>
<script>
export default {
name: "person-clsoe-system",
created() {
this.$electron.ipcRenderer.send("ready-to-show");
},
};
</script>
<style>
/* CSS */
</style>然后打包測(cè)試結(jié)果如下:

到此這篇關(guān)于electron-vue 項(xiàng)目添加啟動(dòng)loading動(dòng)畫問題的文章就介紹到這了,更多相關(guān)electron vue啟動(dòng)動(dòng)畫內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決Vue 瀏覽器后退無法觸發(fā)beforeRouteLeave的問題
這篇文章主要介紹了解決Vue 瀏覽器后退無法觸發(fā)beforeRouteLeave的問題,需要的朋友可以參考下2017-12-12
vue3+vite中開發(fā)環(huán)境與生產(chǎn)環(huán)境全局變量配置指南
最近在使用vite生成項(xiàng)目,這篇文章主要給大家介紹了關(guān)于vue3+vite中開發(fā)環(huán)境與生產(chǎn)環(huán)境全局變量配置的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08
vue-cli webpack模板項(xiàng)目搭建及打包時(shí)路徑問題的解決方法
這篇文章主要介紹了vue-cli webpack模板項(xiàng)目搭建以及打包時(shí)路徑問題的解決方法,需要的朋友可以參考下2018-02-02
vue vantUI tab切換時(shí) list組件不觸發(fā)load事件的問題及解決方法
這篇文章主要介紹了vue vantUI tab切換時(shí) list組件不觸發(fā)load事件的解決辦法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-02-02
使用vue3實(shí)現(xiàn)element-plus的主題切換效果
Vue3 Element Plus是一個(gè)基于Vue 3框架的UI組件庫,它是由Element UI團(tuán)隊(duì)開發(fā)的升級(jí)版本,Element Plus延續(xù)了Element UI簡(jiǎn)潔、高效的風(fēng)格,并引入了一些新的設(shè)計(jì)語言和技術(shù),如響應(yīng)式API和更好的性能優(yōu)化,本文給大家介紹了如何使用vue3實(shí)現(xiàn)element-plus的主題切換效果2024-12-12
element中使用formdata進(jìn)行上傳文件的方法
本文主要介紹了elementUI中使用formdata進(jìn)行上傳文件的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
Element UI 自定義正則表達(dá)式驗(yàn)證方法
今天小編就為大家分享一篇Element UI 自定義正則表達(dá)式驗(yàn)證方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-09-09
vite.config配置alias Error: ENOTEMPTY: director
這篇文章主要為大家介紹了vite.config配置alias時(shí)報(bào)錯(cuò):Error: ENOTEMPTY: directory not empty, rmdir解決方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06

