electron 配置特定文件右键打开

有时候我们需要将electron程序,添加到某类文件的右键打开方式中。使得应用程序能够在用户尝试打开这些文件时自动启动。

1.步骤一

配置文件配置

1.在electron的package.json文件中配置

javascript 复制代码
	"fileAssociations": [
	  {
	    "ext": ["txt"],
	    "name": "Text File",
	    "role": "Editor"
	  }
	]

关联文件类型和角色

在fileAssociations配置中,可以指定文件的扩展名(ext)、名称(name)和角色(role)。角色通常有以下几种:

Editor:编辑器角色,表示应用程序将作为这些文件的默认编辑器。

Viewer:查看器角色,表示应用程序将用于查看这些文件。

Shell:外壳角色,表示应用程序将作为这些文件的默认程序。

权限问题

在使用electron-builder进行打包时,如果遇到fileAssociations配置不生效的问题,可能是由于权限问题。在Windows系统中,可以通过设置nsis配置中的perMachine为false(默认值)来解决权限问题:

javascript 复制代码
"nsis": {
  "perMachine": false
}

2.如果项目是electron-vue ,配置信息可在vue.config.js中进行配置

javascript 复制代码
module.exports = defineConfig({
    pluginOptions:{
        electronBuilder: {
            fileAssociations:[
                {
                  ext:["md","markdown","mmd","mdown","mdtxt","mdtext"],
                  name:"Markdown",
                  description: "Markdown document",
                  role: "Editor",
                  icon: "./public/md.png"
            	}
            ],
        }
    }
})

2.步骤二

在主进程中监听打开事件并获取文件路径

javascript 复制代码
const { app } = require('electron');
app.on('open-file', (event, filePath) => {
  console.log(`File opened: ${filePath}`);
});

注意:
上述方法一定要写在初始化应用的上面
,即:

javascript 复制代码
const { app } = require('electron');
app.on('open-file', (event, filePath) => {
  console.log(`File opened: ${filePath}`);
});
、、、、、
app.whenReady().then(() => {
    createWindow()
  })
相关推荐
鹏多多.13 分钟前
详解vue渲染函数render的使用
前端·javascript·vue.js·前端框架
初心w50t214 分钟前
el-tree的属性render-content自定义样式不生效
前端·javascript·vue.js
19组清风14 分钟前
深入解析 Vite 代码分割原理:从依赖入口点算法到动态导入优化
前端·vite·rollup.js
Luffe船长16 分钟前
vue+elementUI实现固定table超过设定高度显示下拉条
前端·elementui·vue
网络点点滴20 分钟前
什么是Vue.js
前端·javascript·vue.js
非优秀程序员24 分钟前
10 个最佳开源 ChatGPT 替代方案,100% 本地运行
前端·人工智能·后端
curdcv_po25 分钟前
提问:你在项目中使用过 Tailwind CSS 吗?
前端
喝拿铁写前端39 分钟前
前端 Emoji 注释规范实践:VSCode 插件 Emoji 注释增强器分享
前端·开源·代码规范
石小石Orz1 小时前
如何将本地文件转成流数据传递给后端?
前端·vue.js
RPGMZ2 小时前
RPGMZ游戏引擎之如何设计每小时开启一次的副本
javascript·游戏·游戏引擎·rpgmz