Electron结合Vue使用说明
创始人
2024-03-23 18:02:46
0

Electron结合Vue使用说明

1. 创建Vue项目:

npm init vue

2. 创建Electron项目

npm init electron-app@latest electron-project --template=webpack-typescript

npm install copy-webpack-plugin --save-dev

3. 项目配置

1.配置Vue项目:

1)配置base路径

// vite.config.ts
export default defineConfig({plugins: [vue(), vueJsx()],resolve: {alias: {"@": fileURLToPath(new URL("./src", import.meta.url)),},},base: "./", // 新增配置(解决绝对路径导致HTML请求文件失败的问题)
});

2)配置路由为哈希路由

// router/index.ts
import { createRouter, createWebHashHistory } from "vue-router";
import HomeView from "../views/HomeView.vue";const router = createRouter({history: createWebHashHistory(import.meta.env.BASE_URL), // 修改为Hash模式routes: [{path: "/",name: "home",component: HomeView,},{path: "/about",name: "about",component: () => import("../views/AboutView.vue"),},],
});export default router;
2.配置Electron项目

1)修改入口文件,将开发环境与Vue结合

// src/index.ts
// 用于Vue开发环境
if(process.env.npm_lifecycle_event === 'start'){mainWindow.loadURL(<前端项目地址,如('http://localhost:5174')>);
} else {mainWindow.loadURL(MAIN_WINDOW_WEBPACK_ENTRY);
}

2)修改webpack配置,将Vue打包文件整合至Electron打包环境

// webpack.renderer.config.ts
export const rendererConfig: Configuration = {module: {rules},plugins: [// 新增,在打包是将Vue项目整合至Electronnew CopyPlugin({patterns: [{// 将dist目录文件(排除index.html)拷贝至.webpack/renderer/main_windowfrom: "./dist/**",to: ({ context, absoluteFilename }) => {const relativePath = path.relative(context, absoluteFilename).replace(/^dist/, ".");const basePath = path.resolve(__dirname,".webpack/renderer/main_window");return path.resolve(basePath, relativePath);},globOptions: {ignore: ["**/dist/index.html"],},},],}),...plugins,],resolve: {extensions: [".js", ".ts", ".jsx", ".tsx", ".css"],},
};

3)修改forge入口

const config: ForgeConfig = {
packagerConfig: {},rebuildConfig: {},makers: [new MakerSquirrel({}),new MakerZIP({}, ["darwin"]),new MakerRpm({}),new MakerDeb({}),],plugins: [new WebpackPlugin({mainConfig,renderer: {config: rendererConfig,entryPoints: [{html: "./dist/index.html", // 将HTML文件入口指向Vue打包文件js: "./src/renderer.ts",name: "main_window",preload: {js: "./src/preload.ts",},},],},}),],
};

4. 开发

1.运行Vue项目
2.运行Electron项目

5. 打包

1.将Vue打包后的 dist 目录复制到Electron工程根目录
2.打包Electron

相关内容

热门资讯

女生咬男生的胳膊是什么意思? 女生咬男生的胳膊是什么意思?谁告诉我答案应该不是她的个人爱好吧?? 我想不是关系很要好。或者很亲密的...
女朋友让讲故事如何拒绝 女朋友让讲故事如何拒绝如果你不想讲故事,你可以试着以一种礼貌和诚实的方式拒绝。以下是一些可能有用的建...
南京中考分数段公布 转自:扬子晚报根据工作安排,考生的成绩已统计完毕,可通过短信推送、网络查询和考生自行打印成绩通知单等...
无端抹黑!台当局要求民众避免下... 【无端抹黑!#台当局要求民众避免下载5款大陆App#[摊手]】#台青爱玩的大陆App遭台当局无端抹黑...
武林外传60涅80羽现90单职... 武林外传60涅80羽现90单职业魔尊加点(追100)现在斗转便宜,建议你玩双职业
盘古团队最新声明:严格遵循开源... 7月5日下午,华为诺亚方舟实验室在官方平台发布最新声明称,盘古Pro MoE开源模型是基于昇腾硬件平...
受台风“丹娜丝”影响,国家海洋... 转自:北京日报客户端记者从自然资源部获悉,今年第4号台风“丹娜丝”的中心今天(7月5日)16时位于距...
盘古团队最新声明:盘古Pro ... 每经AI快讯,7月5日下午,华为诺亚方舟实验室在官方平台发布最新声明,表示盘古Pro MoE开源模型...
孝敬父母,亲情至上,但对别人很... 孝敬父母,亲情至上,但对别人很自私,不懂感恩的人是个什么样子的人?能知道孝敬父母,自亲自上,但对别人...
马斯克,再提成立美国新政党 据央视新闻,在美国总统特朗普7月4日将“大而美”法案签署成法的几个小时前,特朗普的前盟友、企业家埃隆...