基于Electron+Vite快速構建Vue3桌面應用
前言
隨之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ù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
詳解Vue前端生產(chǎn)環(huán)境發(fā)布配置實戰(zhàn)篇
這篇文章主要介紹了詳解Vue前端生產(chǎn)環(huán)境發(fā)布配置實戰(zhàn)篇,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05