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

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

 更新時(shí)間:2022年01月27日 10:00:02   作者:Serendipity  
electron-vue腳手架搭建的項(xiàng)目,在開發(fā)階段可能你注意不到項(xiàng)目啟動(dòng)慢的問題,但是在build?生成的exe可執(zhí)行文件,啟動(dòng)后,要反應(yīng)很久才能進(jìn)入到app.vue?中加載的頁面,體驗(yàn)性很差,本文給大家介紹electron?vue啟動(dòng)動(dòng)畫效果的實(shí)例代碼,感興趣的朋友一起看看吧

前言

  electron-vue腳手架搭建的項(xiàng)目,在開發(fā)階段可能你注意不到項(xiàng)目啟動(dòng)慢的問題,但是在build 生成的exe可執(zhí)行文件,啟動(dòng)后,要反應(yīng)很久才能進(jìn)入到app.vue 中加載的頁面,體驗(yàn)性很差。

正文

  針對上訴問題,產(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>

?。?)修改主進(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窗口,然后注冊show事件,loading窗口加載了loading.html 頁面后,去加載mainWindow窗口,改窗口加載了頁面app.vue(即index.html)內(nèi)容,并注冊了 " ready-to-show "事件,改事件用于關(guān)閉loading窗口,顯示mainWindow窗口。

  注意:electron-vue 提供了一個(gè)名為__static的全局變量,它將產(chǎn)生一個(gè)指向static/目錄的正確路徑。

  (3)在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>

  然后打包測試結(jié)果如下:

到此這篇關(guān)于electron-vue 項(xiàng)目添加啟動(dòng)loading動(dòng)畫問題的文章就介紹到這了,更多相關(guān)electron vue啟動(dòng)動(dòng)畫內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中使用js-doc的案例代碼

    vue中使用js-doc的案例代碼

    這篇文章主要介紹了vue中使用js-doc的相關(guān)知識(shí),本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-01-01
  • Vite+Electron快速構(gòu)建VUE3桌面應(yīng)用的實(shí)現(xiàn)

    Vite+Electron快速構(gòu)建VUE3桌面應(yīng)用的實(shí)現(xiàn)

    本文主要介紹了Vite+Electron快速構(gòu)建VUE3桌面應(yīng)用的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • vue項(xiàng)目中使用TDesign的方法

    vue項(xiàng)目中使用TDesign的方法

    tdesign-vue是TDesign 適配桌面端的組件庫,適合在 vue 2 技術(shù)棧項(xiàng)目中使用,這篇文章主要介紹了vue項(xiàng)目中使用TDesign?,需要的朋友可以參考下
    2023-04-04
  • vue篇之事件總線EventBus使用示例詳解

    vue篇之事件總線EventBus使用示例詳解

    這篇文章主要為大家介紹了vue篇之事件總線EventBus使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • 深入對Vue.js $watch方法的理解

    深入對Vue.js $watch方法的理解

    本篇文章主要介紹了深入對Vue.js $watch方法的理解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧。
    2017-03-03
  • Vue?echarts實(shí)例項(xiàng)目商家銷量統(tǒng)計(jì)圖實(shí)現(xiàn)詳解

    Vue?echarts實(shí)例項(xiàng)目商家銷量統(tǒng)計(jì)圖實(shí)現(xiàn)詳解

    Echarts,它是一個(gè)與框架無關(guān)的?JS?圖表庫,但是它基于Js,這樣很多框架都能使用它,例如Vue,估計(jì)IONIC也能用,因?yàn)槲业牧?xí)慣,每次新嘗試做一個(gè)功能的時(shí)候,總要新創(chuàng)建個(gè)小項(xiàng)目,做做Demo
    2022-09-09
  • vue使用axios導(dǎo)出后臺(tái)返回的文件流為excel表格詳解

    vue使用axios導(dǎo)出后臺(tái)返回的文件流為excel表格詳解

    這篇文章主要介紹了vue使用axios導(dǎo)出后臺(tái)返回的文件流為excel表格方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue項(xiàng)目使用.env文件配置全局環(huán)境變量的方法

    vue項(xiàng)目使用.env文件配置全局環(huán)境變量的方法

    這篇文章主要介紹了vue項(xiàng)目使用.env文件配置全局環(huán)境變量的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Vue中插入HTML代碼的方法

    Vue中插入HTML代碼的方法

    這篇文章主要介紹了Vue中插入HTML代碼的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09
  • 淺談vue中數(shù)據(jù)雙向綁定的實(shí)現(xiàn)原理

    淺談vue中數(shù)據(jù)雙向綁定的實(shí)現(xiàn)原理

    本篇文章主要介紹了淺談vue中數(shù)據(jù)雙向綁定的實(shí)現(xiàn)原理 ,主要使用v-model這個(gè)數(shù)據(jù)雙向綁定,有興趣的可以了解一下
    2017-09-09

最新評(píng)論