当前位置: 首页 > news >正文

Electron + ts + vue3 + vite

  1. 正常搭建脚手架:npm create vite@latest 项目名称
  2. 安装electron的相关依赖:注:安装时终端url要项目名那一层

  3. 安装npm install electron -D
  4. 安装打包工具:npm install electron-builder -D
  5. 开发工具:npm install electron-devtools-installer -D
  6. 配置文件:npm install vite-plugin-electron -D,npm install vite-plugin-electron-renderer -D
  7. 在项目的根目录下新建electron-main文件夹,之后新建index.ts,配置如下:

    import { app, BrowserWindow } from "electron";
    import * as path from "path";// 本地启动的vue项目路径
    const vueProjectAddress = "http://localhost:5173"
    /*** 创建一个新的窗口*/
    const createWindow = () =>{const win = new BrowserWindow({webPreferences: {contextIsolation: false, // 是否开启隔离上下文nodeIntegration: true, // 渲染进程使用Node API},});if (app.isPackaged) {win.loadFile(path.join(__dirname, "../index.html"));} else {win.loadURL(vueProjectAddress);}
    };
    // 打开窗口
    app.whenReady().then(() => {createWindow(); // 创建窗口app.on("activate", () => {if (BrowserWindow.getAllWindows().length === 0) createWindow();});
    });
    // 关闭窗口
    app.on("window-all-closed", () => {if (process.platform !== "darwin") {app.quit();}
    });
    

  8. 在tsconfig.app.json中的include增加配置"electron-main/**/*.ts" 
    "include": [
    "src/**/*.ts",
    "src/**/*.tsx",
    "src/**/*.vue",
    "electron-main/**/*.ts"
    ]

  9. 在vite.config.ts配置
    import electron from "vite-plugin-electron";
    import electronRenderer from "vite-plugin-electron-renderer";
    export default defineConfig({plugins: [vue(),electron({entry: "electron-main/index.ts", // 主进程文件}),electronRenderer(),],build: {emptyOutDir: false, // 默认情况下,若 outDir 在 root 目录下,则 Vite 会在构建时清空该目录},
    })
    

  10. 打开package.json,增加以下配置:
    {"name": "my-vue-app","private": true,"version": "0.0.0","main": "dist-electron/index.js", // 新增"scripts": {"dev": "vite","build": "vue-tsc && rimraf dist && vite build && electron-builder","preview": "vite preview"},// build 新增"build": {"appId": "com.smallpig.desktop","productName": "smallpig","asar": true,"copyright": "Copyright © 2022 smallpig","directories": {"output": "release/${version}"},"files": ["dist"],"mac": {"artifactName": "${productName}_${version}.${ext}","target": ["dmg"]},"win": {"target": [{"target": "nsis","arch": ["x64"]}],"artifactName": "${productName}_${version}.${ext}"},"nsis": {"oneClick": false,"perMachine": false,"allowToChangeInstallationDirectory": true,"deleteAppDataOnUninstall": false},// 新增"publish": [{"provider": "generic","url": "http://127.0.0.1:8080"}],"releaseInfo": {"releaseNotes": "版本更新的具体内容"}},"dependencies": {"electron-devtools-installer": "^3.2.0","vue": "^3.2.45"},"devDependencies": {"@vitejs/plugin-vue": "^4.0.0","electron": "^22.0.2","electron-builder": "^23.6.0","install": "^0.13.0","npm": "^9.3.0","polyfill-exports": "^0.4.0-beta.2","rimraf": "^4.1.0","typescript": "^4.9.3","vite": "^4.0.0","vite-plugin-electron": "^0.11.1","vite-plugin-electron-renderer": "^0.11.4","vue-tsc": "^1.0.11"}
    }

  11. 在npm run dev即可

http://www.lryc.cn/news/458025.html

相关文章:

  • 《大规模语言模型从理论到实践》第一轮学习--分布式训练
  • 多模态智能
  • 【机器学习(十三)】机器学习回归案例之股票价格预测分析—Sentosa_DSML社区版
  • 大模型微调
  • 240607 继承
  • 轻松应对意外丢失:高效电脑数据恢复指南!
  • vue项目中播放rtsp视频流
  • tomcat部署web配置环境变量
  • 数据仓库技术及应用(练习1)
  • 老板的“神助攻”:公司电脑监控软件
  • 前端vue部署网站
  • Unity3D 动画回调函数详解
  • el-table表格表尾合计行,指定合计某几列,自定义合计方法
  • 一款工具替你解决Mac电脑菜单栏图标杂乱问题
  • MySQL 基础入门教程
  • 俏生元将传统膳食智慧融入现代生活,自然成分绽放健康光彩
  • 腾讯云推流播放相关
  • UE5运行时动态加载场景角色动画任意搭配-相机及运镜(二)
  • @JsonAlias和@JSONField序列化和反序列化
  • k8s1.27部署ingress 1.11.2
  • 【运维】自动化运维详解
  • 线控底盘技术介绍
  • DOM对象
  • [SQL] 数据库图形化安装和使用
  • springboot 前后端处理日志
  • C++11 简单手撕多线程编程
  • 刷c语言练习题7(牛客网)
  • Web Worker和WebSocket
  • 【LeetCode】动态规划—712. 两个字符串的最小ASCII删除和(附完整Python/C++代码)
  • wordpress Contact Form 7插件提交留言时发生错误可能的原因