手工搭建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
相关推荐
共创splendid--与您携手2 小时前
AI读取前端项目生成skill.md
前端·人工智能·ai
San813_LDD3 小时前
[C语言]《Dev-C++ 报错解决手册(Day0607 精华版)》
java·前端·javascript
xiaofeichaichai9 小时前
Webpack
前端·webpack·node.js
问心无愧051310 小时前
ctf show web入门111
android·前端·笔记
唐某人丶10 小时前
模型越来越强,我们还需要 Agent 工程吗?—— 从价值重估到 Harness 实践
前端·agent·ai编程
智码看视界10 小时前
现代Web开发基础:全栈工程师的起航点
前端·后端·c5全栈
JS菌10 小时前
手写一个 AI Agent 全栈项目:从沙箱执行到子智能体的完整实现
前端·人工智能·后端
excel11 小时前
HLS TS 文件损坏的元凶:Git 提交与拉取
前端