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

使用Electron打包vue文件变成exe应用程序

文章目录

  • 一、下载Electron
  • 二、修改下载的Electron项目
    • 1.修改index.html文件
    • 2.修改main.js文件
    • 3.修改package.json文件
  • 三、修改vue项目
    • 1.修改vite.config.js文件
    • 2.修改.env.production文件
    • 3.修改auth.js文件
    • 4.修改router下得index.js文件
    • 6.修改Navbar.vue文件
  • 四、Electron打包


一、下载Electron

克隆下载Electron:
链接: electron-quick-start

1.下载之后安装Electron依赖

npm i -g electron@latest

npm安装electron总失败使用下面的安装方式

npm install -g cnpm --registry=https://registry.npmmirror.com
cnpm install --save-dev electron

2.安装打包运行

cnpm install electron-packager --save-dev

二、修改下载的Electron项目

在这里插入图片描述

1.修改index.html文件

代码如下(示例):

<!DOCTYPE html>
<html>
<head><meta http-equiv="refresh" content="0;url=http://127.0.0.1:12001">
</head>
<body>
<!-- 这里可以添加其他页面内容 -->
</body>
</html>

2.修改main.js文件

代码如下(示例):

// Modules to control application life and create native browser window
const { app, BrowserWindow,Menu, shell } = require('electron')
const path = require('path')function createWindow () {// Create the browser window.const mainWindow = new BrowserWindow({width: 1200,height: 600,webPreferences: {nodeIntegration: true,//取消新增contextIsolation: false,//取消新增路径preload: path.join(__dirname, 'preload.js')}})// and load the index.html of the app.// mainWindow.loadFile('./dist/index.html')//尝试使用绝对路径来进行const indexPath = path.join(__dirname, 'dist', 'index.html');//mainWindow.loadFile(indexPath)mainWindow.loadFile('./dist/index.html'); // 打包的dist路径 把vue打包成dist放到Electron项目的根目录下mainWindow.webContents.openDevTools() // 在这里打开开发者工具// Open the DevTools.// mainWindow.webContents.openDevTools()
}// This method will be called when Electron has finished
// initialization and is ready to create browser windows.
// Some APIs can only be used after this event occurs.
app.whenReady().then(() => {createWindow()app.on('activate', function () {// On macOS it's common to re-create a window in the app when the// dock icon is clicked and there are no other windows open.if (BrowserWindow.getAllWindows().length === 0) createWindow()})
})// Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits
// explicitly with Cmd + Q.
app.on('window-all-closed', function () {if (process.platform !== 'darwin') app.quit()
})// In this file you can include the rest of your app's specific main process
// code. You can also put them in separate files and require them here.

3.修改package.json文件

代码如下(示例):

{"name": "electron-quick-start","version": "1.0.0","description": "A minimal Electron application","main": "main.js","scripts": {"package": "electron-packager ./ aa --platform=win32 --out=release --arch=x64 --overwrite --download.mirrorOptions.mirror=https://npm.taobao.org/mirrors/electron/  --ignore=node_modules"},// aa是生成的文件夹和exe的名字可修改名字"repository": "https://github.com/electron/electron-quick-start","keywords": ["Electron","quick","start","tutorial","demo"],"author": "GitHub","license": "CC0-1.0","devDependencies": {"electron": "^28.1.3","electron-packager": "^17.1.2"}
}

三、修改vue项目

1.修改vite.config.js文件

打包后得路径修改成为./,避免Electron打包exe后显示空白

在这里插入图片描述

2.修改.env.production文件

修改生产环境配置,配置为后端得地址,http://127.0.0.1:8080/ 避免避免Electron打包exe后接口调用不通得问题

在这里插入图片描述

3.修改auth.js文件

修改点击登录后一直转圈,不跳转到index页面得问题,把Cookie获取方式修改成localStorage

在这里插入图片描述

4.修改router下得index.js文件

修改跳转到其他页面空白得问题,路由跳转得问题,把history修改成hash
在这里插入图片描述

6.修改Navbar.vue文件

修改退出登录后页面空白得问题,把location.href修改成router.push({ path: “/login”});

在这里插入图片描述

四、Electron打包

把vue项目打成dist的包,放到Electron项目的根目录下。
在这里插入图片描述
然后在Electron 项目中执行npm run package,进行打包exe,打完包之后在根目录下的release的文件夹中有打包好的exe文件。

在这里插入图片描述

遇到问题文章参考链接:
参考1: spring-boot+vue项目使用 electron打包exe桌面项目,桌面端出现报错Failed to load resource: net::ERR_FILE_NOT_FOUND(解决)
参考2: 使用electron打包exe出现报错 /E:/prod-api/captchaImage:1 Failed to load resource: net::ERR_FILE_NOT_FOUND(若依)
参考3: 使用Electron来给若依系统打包成exe程序,出现登录成功但是不跳转页面(已解决)
参考4: electron /electron-quick-start
参考5: 解决npm安装electron总失败的问题
参考6: Electron的打包windows exe的方法

相关文章:

  • 跨平台Recorder录音插件:支持多种格式、音频可视化、实时上传、语音识别
  • 第二百八十八回
  • 小程序系列--14.小程序分包
  • C#学习笔记_数组
  • ERROR Failed to get response from https://registry.npm.taobao.org/ 错误的解决
  • Linux设备树中的 gpio 信息
  • 网络防御——NET实验
  • 深度学习-搭建Colab环境
  • 序列化和反序列化
  • 1331:【例1-2】后缀表达式的值
  • 一步步安装Ruby攻略
  • MySQL模糊查询通配符转义总结
  • RabbitMQ中交换机的应用及原理,案例的实现
  • 防火墙综合实验
  • 基于固件库的RT-THREAD移植
  • 「面试题」如何实现一个圣杯布局?
  • 【5+】跨webview多页面 触发事件(二)
  • 【知识碎片】第三方登录弹窗效果
  • docker容器内的网络抓包
  • Git初体验
  • Linux编程学习笔记 | Linux多线程学习[2] - 线程的同步
  • MD5加密原理解析及OC版原理实现
  • thinkphp5.1 easywechat4 微信第三方开放平台
  • 包装类对象
  • 互联网大裁员:Java程序员失工作,焉知不能进ali?
  • 漫谈开发设计中的一些“原则”及“设计哲学”
  • 面试遇到的一些题
  • 区块链分支循环
  • 限制Java线程池运行线程以及等待线程数量的策略
  • 一个完整Java Web项目背后的密码
  • 移动互联网+智能运营体系搭建=你家有金矿啊!
  • 宾利慕尚创始人典藏版国内首秀,2025年前实现全系车型电动化 | 2019上海车展 ...
  • 分布式关系型数据库服务 DRDS 支持显示的 Prepare 及逻辑库锁功能等多项能力 ...
  • ​configparser --- 配置文件解析器​
  • ​Distil-Whisper:比Whisper快6倍,体积小50%的语音识别模型
  • ​HTTP与HTTPS:网络通信的安全卫士
  • ​你们这样子,耽误我的工作进度怎么办?
  • #每天一道面试题# 什么是MySQL的回表查询
  • (20050108)又读《平凡的世界》
  • (6)设计一个TimeMap
  • (M)unity2D敌人的创建、人物属性设置,遇敌掉血
  • (层次遍历)104. 二叉树的最大深度
  • (转)GCC在C语言中内嵌汇编 asm __volatile__
  • (转)大型网站架构演变和知识体系
  • (转)机器学习的数学基础(1)--Dirichlet分布
  • (转载)Linux网络编程入门
  • ***原理与防范
  • .locked1、locked勒索病毒解密方法|勒索病毒解决|勒索病毒恢复|数据库修复
  • .net 后台导出excel ,word
  • .Net高阶异常处理第二篇~~ dump进阶之MiniDumpWriter
  • .NET框架
  • .xml 下拉列表_RecyclerView嵌套recyclerview实现二级下拉列表,包含自定义IOS对话框...
  • @RequestMapping用法详解
  • [ 网络基础篇 ] MAP 迈普交换机常用命令详解
  • [2023年]-hadoop面试真题(一)