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

基于Electron+Vite快速構建Vue3桌面應用

 更新時間:2023年07月02日 09:51:59   作者:麥忙  
這篇文章主要介紹了如何基于Electron和Vite快速構建Vue3桌面應用,本文主要技術棧就是Vue3、vite、Electron,文中有詳細的代碼示例,需要的朋友可以參考下

前言

隨之Vite的不斷地受歡迎,大家應該都在使用了,最近公司需要開發(fā)一個桌面的視頻播放器,這就涉及到了Electron,它可以幫助我們快速的開發(fā)一個桌面級別的應用,下面是我搭建的基本架子,主要技術棧就是Vue3 vite Electron

創(chuàng)建應用

我們利用Vite 構建Vue3項目,直接一行命令, 我這里選擇yarn,當然npm pnpm這些都是可以的,看自己習慣了

# yarn yarn create vite electron-demo --template vue

進入項目下載依賴,運行項目

// 進入項目
cd electron-demo
// 下載依賴
yarn
// 運行項目
yarn dev

這些都是比較熟悉的!不出意外的項目啟動成功

下載Electron

正菜來了,正事開啟踩坑之旅

yarn add electron

由于國內(nèi)下載Electron 是無法下載,要么報錯,要么就是卡住不動,解決辦法如下 將Electron設置國內(nèi)鏡像后,可以加快文件的下載速度,下面是 electron的國內(nèi)鏡像設置。

pnpm config set electron_mirror=https://npm.taobao.org/mirrors/electron/
pnpm config set electron_builder_binaries_mirror=https://npm.taobao.org/mirrors/electron-builder-binaries/

配置

修改package.json

  • 首先在根目錄新建 electron / index.js

 

這里存放的就是Electron的主進程文件,方便后期管理,里面的具體配置大家可以去ELectron 官網(wǎng)了解

// electron / index.js
import { app, BrowserWindow } from 'electron';
import { join } from 'path'
const createdWindow = () => {
  const win = new BrowserWindow({
    width:900,
    height:600,
    webPreferences: {
      nodeIntegration: true,
      contextIsolation:false,
    }
  })
}
app.whenReady().then(createdWindow)
  • 配置vite-plugin-electron插件需要進行打包編譯的文件入口。

yarn add vite-plugin-electron -D

打開vite.config.js引入執(zhí)行配置,將入口文件寫入,就是我們剛剛新建的主線程文件

import { app, BrowserWindow } from 'electron';
import { join } from 'path'
const createdWindow = () => {
  const win = new BrowserWindow({
    width:900,
    height:600,
    webPreferences: {
      nodeIntegration: true,
      contextIsolation:false,
    }
  })
  if(process.env.VITE_DEV_SERVER_URL){
    win.loadURL(process.env.VITE_DEV_SERVER_URL)
  }else {
    win.loadFile(join(__dirname,'index.html'))
  }
}
app.whenReady().then(createdWindow)
  • 運行項目 yarn dev

我們可以看到新增一個文件夾,這里就是編譯過后的主線程的代碼,同時會有一個報錯

由于electron主進程是使用的node環(huán)境,而默認情況下,Node.js 使用的是 CommonJS 模塊規(guī)范,而 import 語句屬于 ECMAScript 模塊規(guī)范,兩者不兼容。所以需要使用編譯為 CommonJS 規(guī)范的dist-electron/main.js作為main屬性的入口文件,否則會報es6語法錯誤。

這個時候我們將packjson中的type字段去除,將入口文件改為dist-electron/main.js

{
  "name": "electorn-demo",
  "private": true,
  "version": "0.0.0",
  "main": "dist-electron/index.js",
  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "preview": "vite preview"
  },
  "dependencies": {
    "vue": "^3.2.47"
  },
  "devDependencies": {
    "@vitejs/plugin-vue": "^4.1.0",
    "electron": "^25.1.0",
    "vite": "^4.3.9",
    "vite-plugin-electron": "^0.11.2"
  }
}

這個時候我們就能看到一個桌面級別的成品了

  • 終斷亂碼

接下來還會存在一個問題就是主進程里在終斷打印中文亂碼的問題,這里提供一個解決辦法

解決辦法

chcp 65001 是 Windows 系統(tǒng)下的一個命令,用于將控制臺的代碼頁設置為 UTF-8 編碼。在默認情況下,Windows 控制臺使用的是 GBK 或者其他本地編碼,導致在控制臺中輸出中文等非 ASCII 字符時可能會出現(xiàn)亂碼。 使用 chcp 65001 命令可以將控制臺的代碼頁設置為 UTF-8 編碼,以便正確顯示中文等非 ASCII 字符。

打包Electron

需要安裝electron-builder cross-env

yarn add electron-builder cross-env -D

修改packjsons的文件

"build": "vite build && electron-builder"

修改electron/index.js,讓打包后的軟件可以正確加載

import { app, BrowserWindow } from 'electron';
import { join } from 'path'
const createdWindow = () => {
  const win = new BrowserWindow({
    width:900,
    height:600,
    webPreferences: {
      nodeIntegration: true,
      contextIsolation:false,
    }
  })
  if(process.env.NODE_ENV !='development'){
    win.loadFile(join(__dirname,'../dist/index.html'))
  }else {
    win.loadURL(process.env.VITE_DEV_SERVER_URL)
  }
}
app.whenReady().then(createdWindow)

最后一步:將下面代碼復制到packjson.json 文件中

"build": {
    "appId": "com.my-website.my-app",
    "productName": "MyApp",
    "copyright": "Copyright ? 2021 kuari",
    "mac": {
      "category": "public.app-category.utilities"
    },
    "nsis": {
      "oneClick": false,
      "allowToChangeInstallationDirectory": true
    },
    "files": [
      "dist/**/*",
      "dist-electron/**/*"
    ],
    "directories": {
      "buildResources": "assets",
      "output": "release/"
    }
  }

成果

執(zhí)行yarn build就會看到文件根目錄新增了一個我們設置的release文件,里面存放的就是我們的軟件,點擊安裝后就大公告成了

這就是基本的搭建了,后面可能會繼續(xù)更新electron的相關知識!!!

到此這篇關于基于Electron+Vite快速構建Vue3桌面應用的文章就介紹到這了,更多相關Electron+Vite Vue3桌面應用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 如何去除element-ui中table的hover效果

    如何去除element-ui中table的hover效果

    這篇文章主要介紹了如何去除element-ui中table的hover效果,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue實現(xiàn)美團app的影院推薦選座功能【推薦】

    Vue實現(xiàn)美團app的影院推薦選座功能【推薦】

    大家都經(jīng)常使用美團app買電影票,很多朋友不知道她的功能是怎么實現(xiàn)的,作為我程序員一枚對它的算法很好奇,今天小編就把基于Vue實現(xiàn)美團app的影院推薦選座功能分享到腳本之家平臺,感興趣的朋友一起看看吧
    2018-08-08
  • 詳解Vue前端生產(chǎn)環(huán)境發(fā)布配置實戰(zhàn)篇

    詳解Vue前端生產(chǎn)環(huán)境發(fā)布配置實戰(zhàn)篇

    這篇文章主要介紹了詳解Vue前端生產(chǎn)環(huán)境發(fā)布配置實戰(zhàn)篇,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-05-05
  • vue.js中ref及$refs的使用方法解析

    vue.js中ref及$refs的使用方法解析

    這篇文章主要介紹了vue.js中ref及$refs的使用方法解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-10-10
  • 全局引入vant后使用Toast的問題及解決

    全局引入vant后使用Toast的問題及解決

    這篇文章主要介紹了全局引入vant后使用Toast的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue-i18n實現(xiàn)中英文切換的方法

    vue-i18n實現(xiàn)中英文切換的方法

    這篇文章主要介紹了vue-i18n實現(xiàn)中英文切換的方法,文中示例代碼非常詳細,幫助大家更好的理解和學習,感興趣的朋友可以了解下
    2020-07-07
  • Vue事件中如何獲取原事件參數(shù)

    Vue事件中如何獲取原事件參數(shù)

    文章介紹了如何在Vue中通過Click方法獲取原事件的參數(shù),包括默認參數(shù)、自定義參數(shù)以及如何同時獲取原生事件和自定義參數(shù)的方法
    2024-12-12
  • 關于Vue.js一些問題和思考學習筆記(1)

    關于Vue.js一些問題和思考學習筆記(1)

    這篇文章主要為大家分享了關于Vue.js一些問題和思考的學習筆記,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • vue強制刷新組件的三種方法

    vue強制刷新組件的三種方法

    在Vue中,強制刷新組件通常涉及到以下幾種方法,本文給大家列出了常見的三種vue強制刷新組件的方法,感興趣的朋友跟隨小編一起看看吧
    2024-04-04
  • vue中監(jiān)聽scroll事件失效的問題及解決

    vue中監(jiān)聽scroll事件失效的問題及解決

    這篇文章主要介紹了vue中監(jiān)聽scroll事件失效的問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09

最新評論