IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3+vite+electron+electron-builder 实现vue3和electron结合 -> 正文阅读

[JavaScript知识库]vue3+vite+electron+electron-builder 实现vue3和electron结合

vite+vue3+electron桌面端开发

ps :踩坑踩了一个多小时 如果嫌麻烦可以直接拿走用

克隆代码仓库

1.https://gitee.com/dmhsq/vue3-vite-electron
https://gitee.com/dmhsq/vue3-vite-electron.git

2.https://github.com/promiseHusky/vue3-vite-electron
https://github.com/promiseHusky/vue3-vite-electron.git

同样你也可以使用脚手架 来快速的创建 [还没写完 先用着仓库的吧]

效果如下

这是打包生成的

在这里插入图片描述
如下图是 生成的安装包 选择了 mis 和 nsis
在这里插入图片描述

在这里插入图片描述

安装使用

下载代码后 进入项目目录

执行 npm install 安装依赖
执行 npm start 为开发模式
执行 npm dist 为打包项目并且生成 安装包

踩坑过程

由于 vite打包默认生成 dist目录
而 electron-builder打包也是生成 dist目录
所以 配置了 vite的build.outDir为 ‘build’
同样vite的配置 base: ‘./’, 这里处理了读取不到 资源文件

为了方便使用 main.js 这里使用了webpack打包
因为对vite不熟悉 我得理解是得有 index.html文件作为入口?
但是我只想打包 main.js以及相关引用 所以 使用了webpack5

如果你想修改 electron的logo
可以将 public目录下的logo.ico换成你想用的 注意这里也有一个坑 就是 生成的logo像素至少为 256x256否则会在打包的时候报错

开发注意

因为这里使用的是高版本electron
如果你想在 vue文件中 引入remote

需要安装一个依赖包 @electron/remote
还需要在 main.js里面编写如下代码
以此项目代码为演示 如下 (这里默认为我们的vue项目 如果你需要引入自定义的html并且使用remote见下面的注释代码)

const { app, Menu } = require('electron');
const isDev = require('electron-is-dev');
const AppWindow = require('./src/utils/AppWindow.js');
const menuItems = require('./menu.config.js');
const path = require('path');

app.on('ready', () => {
  const mainWindowConfig = {
    width: 1440,
    height: 768,
  };
  const urlLocation = isDev
    ? 'http://localhost:3000'
    : `file://${path.join(__dirname, './index.html')}`;
  mainWindow = new AppWindow(mainWindowConfig, urlLocation);
  mainWindow.on('closed', () => {
    mainWindow = null;
  });
  require('@electron/remote/main').initialize();
  require('@electron/remote/main').enable(mainWindow.webContents);

  // const divWindowConfig = {
  //   width: 1440,
  //   height: 768,
  // };
  // const divUrlLocation = "xxxxx"
  // const divWindow = new AppWindow(divWindowConfig, divUrlLocation);
  // require('@electron/remote/main').enable(divWindow.webContents);
  const menu = Menu.buildFromTemplate(menuItems);
  Menu.setApplicationMenu(menu);
});

Version

0.0.0

说明

刚刚搭建完成 可实现基础的 运行 打包

下个版本

更新时间预估为下个月 这个月忙

1.自动更新
2.更加丰富的菜单配置案例(持续,部分更新)
3.封装一些electron基础操作 可通过 $electon执行
4.推出接入uniCloud的云开发模式 预估通过axios控制来实现

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-12 17:23:13  更:2022-03-12 17:23:35 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:09:27-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码