electron 命令行参数的踩坑

vite + vue + ts + electron

想要为 electron 编译出来的程序加上命令行参数的控制,比如 app port address, 来让 app 在 port 端口上开启,并获得配置中心 address 的相关信息。

以下是 npm run dev 的插件配置

javascript 复制代码
export const ElectronDevPlugin = (): Plugin => {
    return {
        name: "electron-dev",
        configureServer(server) {
            server?.httpServer?.once("listening", () => {
                build()  // 编译 cjs 文件,可以忽视
                const addressInfo = server.httpServer?.address() as AddressInfo
                const IP = `http://localhost:${addressInfo.port}`
                // 用 electron 来编译 vue 生成的 dist
                var process = spawn(electron.toString(), ["dist/background.cjs", IP])
                fs.watchFile("src/background.ts", () => {
                    process.kill()
                    build()
                    process = spawn(electron.toString(), ["dist/background.cjs", IP])
                })
            })
        }
    }
}

spawn(electron.toString(), ["dist/background.cjs", IP]) 这一步本质上是调用了electron.exe dist/background.cjs IP 这段命令,导致一开始认为 electron.exe 的编译程序可以直接传入命令行参数,并通过process.argv的方式来获得传入的 IP 信息

以下是background.ts中的代码

arduino 复制代码
app.whenReady().then(() => {
    const win = new BrowserWindow({
        height: 600,
        width: 800,
        webPreferences: {
            nodeIntegration: true,
            contextIsolation: false,
            webSecurity: false,
        }
    }) 

    if (process.argv[2]) {
        win.loadURL(process.argv[2])
    } else {
        win.loadFile("index.html")
    }
})

这段代码其实就是将 electron.exe dist/background.cjs IP 编译时传入的 IP(process.argv[2]) 当作 app 的界面的源信息。

但在后来的测试之中发现,electron.exe 本身只支持两种参数 options 和 path

因此如果传入第三个参数进去的话,electron.exe 就会直接退出(不是你至少给个报错啊)

但是就像之前的 npm run dev 的插件代码中写的,直接使用 electron.exe 编译的话,是可以获取到 IP 的参数的,所以那段插件代码本质上是将 dist/background.cjs 填在了 path 的位置,而后边的 IP 则是靠着 electron 对命令行的监控不严混进去的(electron 允许最多两个参数),最终在 background.ts 之中被 process.argv 捕获,结果就导致了 electron 编译的时候好像可以传递命令行参数的错觉。

所以,如果 electron 编译后的程序想要传递命令行参数的话,应该直接在编译完成之后的 release 文件之中使用 ./app port address 来运行,然后如果 npm run dev 的插件采用的也是需要 process.argv 来进行一些操作的话,那么就需要将 npm run dev 对于 process.argv 的处理和 ./app 本身对于 process.argv 分开。

目前想到的要么就是 release 的时候直接从代码上换成另一套处理,要么就是 npm run dev 运行自己的脚本来进行手动的编译。

相关推荐
web打印社区13 小时前
web-print-pdf:突破浏览器限制,实现专业级Web静默打印
前端·javascript·vue.js·electron·html
NBhhbYyOljP18 小时前
自组织特征映射(SOM)的数据聚类程序。 matlab程序 数据格式为excel
electron
web打印社区2 天前
前端开发实现PDF打印需求:从基础方案到专业解决方案
前端·vue.js·react.js·electron·pdf
web打印社区2 天前
vue页面打印:printjs实现与进阶方案推荐
前端·javascript·vue.js·electron·html
像风一样自由20203 天前
解决百度网盘安装报错:D 盘 package.json 触发 Electron ESM/CJS 冲突
javascript·electron·json
mseaspring3 天前
一款高颜值SSH终端工具!基于Electron+Vue3开发,开源免费还好用
运维·前端·javascript·electron·ssh
熊猫钓鱼>_>4 天前
从零到一:打造“抗造” Electron 录屏神器的故事
前端·javascript·ffmpeg·electron·node·录屏·record
小圣贤君4 天前
Electron 桌面应用接入通义万相:文生图从 0 到 1 实战
前端·electron·ai写作·通义万相·ai生图·写作软件·小说封面
GDAL4 天前
Electron 快速入门教程
前端·javascript·electron
GDAL4 天前
Electron IPC 通信深入全面讲解教程
javascript·electron