手工搭建PC端:pnpm + Vite + Vue3 + Element Plus + Electron

初始化项目

复制代码
mkdir electron-vue3
cd electron-vue3
pnpm init 

安装Vite + Vue3 + Element Plus

复制代码
pnpm add vue@latest
pnpm add -D vite @vitejs/plugin-vue
pnpm add element-plus
pnpm add @element-plus/icons-vue

安装Electron

复制代码
pnpm add -D electron electron-builder
pnpm add -D vite-plugin-electron vite-plugin-electron-renderer

创建静态文件入口:index.html

复制代码
<!doctype html>
<html lang="en">

<head>
  <meta charset="UTF-8" />
  <link rel="icon" type="image/svg+xml" href="/favicon.svg" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <title>electron-vue3</title>
</head>

<body>
  <div id="app"></div>
  <script type="module" src="/src/main.js"></script>
</body>

</html>

创建样式文件:src/assets/style.css

复制代码
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

创建Vue根组件:src/App.vue

复制代码
<template>
  <h1>Vue3 + Element Plus</h1>
  <el-button type="primary">测试按钮</el-button>
</template>

创建入口文件:src/main.js

复制代码
import { createApp } from 'vue'
import App from './App.vue'
import './assets/style.css'
import ElementPlus from 'element-plus'
import * as ElementPlusIconsVue from '@element-plus/icons-vue'
import 'element-plus/dist/index.css'

const app = createApp(App)
app.use(ElementPlus)
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component)
}
app.mount('#app')

创建Electron主进程文件:electron/main.js

复制代码
const { app, BrowserWindow } = require('electron')
const path = require('path')

let win

function createWindow() {
  win = new BrowserWindow({
    width: 1000,
    height: 700,
    webPreferences: {
      nodeIntegration: true,
      contextIsolation: false
    }
  })

  if (process.env.VITE_DEV_SERVER_URL) {
    win.loadURL(process.env.VITE_DEV_SERVER_URL)
    win.webContents.openDevTools()
  } else {
    win.loadFile(path.join(__dirname, '../dist/index.html'))
  }
}

app.whenReady().then(createWindow)

app.on('window-all-closed', () => {
  if (process.platform !== 'darwin') app.quit()
})

app.on('activate', () => {
  if (BrowserWindow.getAllWindows().length === 0) createWindow()
})

创建Electron渲染进程的预加载脚本文件:electron/preload.js

复制代码
console.log('preload 已加载')

Vite核心配置文件:vite.config.js

复制代码
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import electron from 'vite-plugin-electron'
import renderer from 'vite-plugin-electron-renderer'

export default defineConfig({
  plugins: [
    vue(),
    electron([
      {
        entry: "electron/main.js"
      },
      {
        entry: "electron/preload.js"
      }
    ]),
    renderer()
  ],
  server: {
    port: 3000
  }
})

创建.npmrc(npm/pnpm/yarn的配置文件)

复制代码
# Electron国内镜像
electron_mirror=https://npmmirror.com/mirrors/electron/
electron_builder_binaries_mirror=https://npmmirror.com/mirrors/electron-builder-binaries/

# PNPM专用配置
node_mirror=https://npmmirror.com/mirrors/node/
registry=https://registry.npmmirror.com/

修改Node.js核心配置文件:package.json

复制代码
  "main": "electron/main.js",


  "scripts": {
    "dev": "vite",
    "build": "vite build",
    "start": "electron .",
    "electron:dev": "vite",
    "electron:build": "vite build && electron-builder"
  },

运行项目

复制代码
pnpm electron:dev

打包项目

复制代码
pnpm electron:build
相关推荐
kyriewen19 小时前
我手写了一个 EventEmitter,面试官追问了 6 个问题——第 4 个我没答上来
前端·javascript·面试
IT_陈寒19 小时前
Java的Date类又坑了我一次,改用时间戳真香
前端·人工智能·后端
小林攻城狮20 小时前
使用 Transport 节流解决 Vercel AI SDK 流式渲染卡死问题
前端·react.js
前端缘梦20 小时前
告别 TS 运行时类型漏洞!Zod 完整入门实战教程(前端 / 全栈必备)
前端·react.js·全栈
the_answer21 小时前
Webpack vs Vite 深度对比分析
前端·webpack
转转技术团队21 小时前
验证码识别实战:前端不写页面,改训模型了?
前端
MomentYY21 小时前
Temperature:AI 的“脑洞旋钮”
前端·llm·ai编程
远航_21 小时前
OpenSpec 完整详细介绍
前端·后端
召钱熏21 小时前
状态枚举正确≠渲染正确:一个语音按钮的状态机边界修复实录
android·前端
SkyWalking中文站21 小时前
认识 Horizon UI · 1/17:SkyWalking 新一代可观测性控制台
运维·前端·监控