electron-vite工具打包后通过内置配置文件动态修改接口地址实现方法

系列文章目录

electron+vite+vue3 快速入门教程

文章目录


前言

使用electron-vite 工具开发项目打包完后每次要改接口地址都要重新打包,对于多环境切换或者频繁变更接口地址就显得麻烦。如果能在安装目录添加一个可配置文件,通过修改配置文件内容改变接口地址问题将迎刃而解。这里记录下一种实现方法。


一、实现过程

1、配置文件(json格式)放置resources资源文件夹下,将同步打包到应用内部,安装后可在安装目录找到

2、启动应用时在App.vue通知主进程通过node fs模块读取配置文件接口地址,并缓存到本地

3、接口请求封装文件(axios)baseURL从本地缓存获取

二、代码演示

1.resources/env.json

c 复制代码
{
  "baseUrl":"http://192.168.2.xxx:xxxx"
}

新建一个json文件内置接口地址

2.App.vue

javascript 复制代码
<script setup>
import { ref, onBeforeMount } from 'vue'
onBeforeMount(async () => {
  let url = await window.electron.ipcRenderer.invoke('baseUrl')
  if (url) {
    localStorage.setItem('baseUrl', url)
  }
})
</script>

应用启动开始时从主进程获取接口地址,缓存到本地localStorage(当然也可以选择缓存到pinia或vuex等)

3.main/index.js

javascript 复制代码
const fs = require('fs');
//获取接口baseurl
ipcMain.handle('baseUrl',()=>{
  const rawData = fs.readFileSync(join(__dirname, '../../resources/env.json'),"utf-8");
  const config = JSON.parse(rawData);
  return config.baseUrl||''
})

主进程通过fs读取env.json内接口地址返回给渲染层

4.request.js

javascript 复制代码
const baseURL = localStorage.getItem('baseUrl')??''
const http = axios.create({
  baseURL,
  timeout: 100000,
   .....
   .....
})
.....
.....

接口请求统一封装文件内,从缓存获取接口地址并设置

5.安装后修改

打开安装目录,在resources\app.asar.unpacked\resources文件夹下可找到env.json配置文件,修改完配置完全退出应用并重启生效

相关推荐
狮子座的男孩8 分钟前
js基础:10、函数对象方法(call/apply)、arguments类数组对象、Date对象、Math工具类、包装类、字符串方法、正则表达式
前端·javascript·正则表达式·包装类·字符串方法·arguments·date对象
jackzhuoa16 分钟前
Rust 异步核心机制剖析:从 Poll 到状态机的底层演化
服务器·前端·算法
JIngJaneIL24 分钟前
财务管理|基于SprinBoot+vue的个人财务管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设·财务管理系统
qq_3380329233 分钟前
VUE的生命周期钩子,vue2和vue3的生命周期钩子的核心差异
前端·javascript·vue.js
IT_陈寒1 小时前
Vue3性能翻倍秘籍:5个Composition API技巧让你的应用快如闪电⚡
前端·人工智能·后端
Dontla1 小时前
npm install命令介绍
前端·npm·node.js
天天向上10241 小时前
在 Vue3 项目中使用 el-tree
javascript·vue.js·elementui
天天向上10241 小时前
vue2 vue3 修改elementUI和elementPlus主题颜色
前端·javascript·elementui
Zhangzy@1 小时前
Rust Workspace 构建多项目体系
开发语言·前端·rust
通往曙光的路上1 小时前
day23_密码加密 前端验证码 监听器 svn版本控制
前端·svn