探索 Electron:快捷键与剪切板操作

Electron是一个开源的桌面应用程序开发框架,它允许开发者使用Web技术(如 HTML、CSS 和 JavaScript)构建跨平台的桌面应用程序,它的出现极大地简化了桌面应用程序的开发流程,让更多的开发者能够利用已有的 Web 开发技能来构建功能强大且跨平台的应用程序,这对于提升开发效率和应用程序的快速交付具有重要意义。

目录

快捷键

剪切板


快捷键

        在应用程序没有键盘焦点时,我们可以通过监听键盘事件globalShortcut模块可以在操作系统中注册/注销全局快捷键, 以便可以为操作定制各种快捷键。

注意:因为快捷方式是全局的,即使应用程序没有键盘焦点,它也仍然在持续监听键盘事件,在应用程序模块发出ready事件之前,不应该使用此模块,这里我们通过一段代码对快捷键的注册和销毁做一下演示:

// app应用;BrowserWindow 窗口
const { app, BrowserWindow, globalShortcut } = require('electron')
const path = require('path')const createWindow = () => {const win = new BrowserWindow({ // 窗口的配置width: 800, height: 600, icon: 'logo.png', title: "亦世凡华、",webPreferences: {preload: path.resolve(__dirname, './preload.js') // 预加载脚本}        })win.loadFile('./src/index.html') // 加载页面globalShortcut.register('g', () => {console.log("快捷键 g 注册成功")})globalShortcut.register('h', () => {console.log("将快捷键 g 注销掉")globalShortcut.unregister('g')})
}

这里我们通过桌面端界面的演示,可以看到我们的快捷键被注册和销毁成功了:

如果想在桌面端退出的时候取消某个或者全部的快捷键,可以在生命周期will-quit进行,如下:

// 桌面端快要退出的时候,注销快捷键
app.on('will-quit', () => {globalShortcut.unregister('ctrl + q') // 注销单个快捷键globalShortcut.unregisterAll() // 注销所有快捷键
})

剪切板

剪切在桌面端是常见的功能,顾名思义就是在系统剪贴板上执行复制和粘贴操作,然后最新版本的electron中给其加了一个限制就是只能在非沙盒下使用,如下:

什么是沙盒:是一种安全机制,用于增强应用程序的安全性和稳定性,它主要通过限制渲染进程(web 页面)的权限来实现,例如只允许访问特定目录或文件。这可以防止恶意代码修改或删除用户的文件。

在最新版本的 Electron 中,沙盒机制是可选的,并且需要在应用程序的启动配置中明确启用。它不仅限制了渲染进程的权限,还提供了一些额外的安全性措施,如堆栈限制和沙盒内的特权分离。这些措施有助于最大程度地隔离和保护渲染进程,确保即使出现漏洞,也不会波及到整个应用程序或用户系统。所以如果我们想开启剪切操作,则需要关闭沙盒,如下:

接下来我们就需要在预加载脚本中编写相应的剪切clipboard函数的操作,然后在渲染进行中进行调用了,代码过程如下所示:

最终呈现的效果如下所示:

当然这里我们也可以对图片进行一个剪切粘贴的操作,这里我们在预加载脚本文件中进行如下操作,这里我们借助 Electron 框架中的一个模块,用于创建原生的图像对象,可以通过 NativeImage 创建和操作系统级别相关的图像对象,例如窗口图标、菜单图标、应用程序图标等。它提供了一种跨平台的方式来处理和操作图像,使开发者能够在 Electron 应用中使用原生的图像功能:

const { contextBridge, clipboard, nativeImage } = require("electron")// 复制文本
const copy = (data) => {clipboard.writeText(data)
}
// 读取文本
const read = (data) => {return clipboard.readText(data)
}
// 复制图片
const addImage = (data) => {// 将图片放置于剪切板当中的时候要求图片类型属于 nativeImage 实例let oImagg = nativeImage.createFromPath(data)clipboard.writeImage(oImagg)// 将剪切板中的图片作为dom元素显示在界面上let oImg = clipboard.readImage()let oImgDom = new Image()oImgDom.src = oImg.toDataURL()document.body.appendChild(oImgDom)
}contextBridge.exposeInMainWorld('myAPI', {copy,read,addImage
})

然后我们在渲染进行进行调用函数然后传递对应的图片路径即可,如果控制台报出图片资源相关的错误问题,可以在index.html文件中替换一下下面的文件即可:

<meta http-equiv="Content-Security-Policy" content="connect-src *; default-src 'self' data: gap: https://ssl.gstatic.com 'unsafe-eval'; script-src 'self' 'unsafe-inline'; style-src 'self' 'unsafe-inline'; media-src *; img-src 'self' data: content:;">

最终呈现的效果如下所示:

当然还有一些其他的功能如下,其他功能就不再详细赘述了,后面做项目用到的时候再进行阐述吧

shell模块:提供与桌面集成相关的功能,在用户的默认浏览器中打开url:

const { shell } = require('electron')
shell.openExternal('https://www.baidu.com') // 打开外部链接
shell.showItemInFolder(path.resolve(__dirname)) // 打开文件管理器

消息通知:通过Notification我们可以在桌面端中向电脑发送消息:

window.onload = function() {let btn = document.getElementsByClassName("btn")[0];btn.addEventListener('click', ()=> {let option = {title: '亦世凡华、',body: '一键三联,求关注',icon: './logo.png'}new Notification(option.title, option);})
}

最终呈现的效果如下所示:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3267672.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

C++:类和对象2

1.类的默认成员函数 默认成员函数就是用户没有显示实现编译器会自动生成的成员函数称为默认成员函数。一个类&#xff0c;我们在不写的情况下编译器会默认生成6个默认成员函数&#xff0c;分别是构造函数&#xff0c;析构函数&#xff0c;拷贝构造函数&#xff0c;拷贝赋值运算…

GPT-4引领:AI新浪潮的转折点

OneFlow编译 **翻译&#xff5c;贾川、杨婷、徐佳渝 编辑&#xff5c;王金许** 一朝成名天下知。ChatGPT/GPT-4相关的新闻接二连三刷屏朋友圈&#xff0c;如今&#xff0c;这些模型背后的公司OpenAI的知名度不亚于任何科技巨头。 不过&#xff0c;就在ChatGPT问世前&#x…

Reaxys平台账号创建:简易注册流程

Reaxys数据库是Elsevier旗下的全球最大物质理化性质和事实反应数据库&#xff0c;包含了超过5亿条经过实验验证的物质信息&#xff0c;收录超过1.38亿种化合物&#xff0c;5,000万种单步和多步反应、6,000万条文摘记录。涵盖全球7大专利局和16,000种期刊16个学科中与化合物性质…

全网最详细Gradio教程系列5——Gradio Client: python

全网最详细Gradio教程系列5——Gradio Client: python 前言本篇摘要5. Gradio Client的三种使用方式5.1 使用Gradio Python Client5.1.1 安装gradio_client5.1.2 连接Gradio应用程序1. 通过URL连接2. 通过SpaceID连接3. 辅助&#xff1a;duplicate()和hf_token4. Colab Noteboo…

ajax学习1

<!-- 目标&#xff1a;使用axios库&#xff0c;获取省份列表数据&#xff0c;展示到页面上 1.引入axios库 --> <p class"my-p"></p> <script src"https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></ script> <sc…

Tomcat项目本地部署

今天来分享一下如何于本机上在不适用idea等辅助工具的前提下&#xff0c;部署多个tomcat的web项目 我这里以我最近写的SSM项目哈米音乐为例&#xff0c;简单介绍一下项目的大致组成&#xff1a; 首先&#xff0c;项目分为4个模块&#xff0c;如下图所示&#xff1a; 其中&…

力扣高频SQL 50题(基础版)第十八题

文章目录 力扣高频SQL 50题&#xff08;基础版&#xff09;第十八题1633. 各赛事的用户注册率题目说明思路分析实现过程准备数据实现方式结果截图 力扣高频SQL 50题&#xff08;基础版&#xff09;第十八题 1633. 各赛事的用户注册率 题目说明 用户表&#xff1a; Users --…

RPG素材Unity7月20闪促限时4折游戏开发资产兽人角色模型动画休闲放置模板物理交互流体水下焦散VR界面UI2D模板场景20240720

今天这个是RPG素材比较多&#xff0c;还有一些休闲放置模板、FPS场景素材、角色模型、动画、特效。 详细内容展示&#xff1a;www.bilibili.com/video/BV1Tx4y1s7vm 闪促限时4折&#xff1a;https://prf.hn/l/0eEOG1P 半价促销&#xff1a;https://prf.hn/l/RlDmDeQ 7月闪促…

小红书(社招二面)算法原题

萝卜快跑涨价 距离我们上次谈 萝卜快跑 不足半月&#xff0c;萝卜快跑迎来了不少"反转"。 先是被曝远程后台有人操控&#xff0c;真实日成本超 400&#xff1a; 最近还被不少网友吐槽&#xff1a;萝卜快跑涨价了&#xff0c;如今价格和网约车持平。 据不少博主实测&a…

17 Python常用内置函数——基本输入输出

input() 和 print() 是 Python 的基本输入输出函数&#xff0c;前者用来接收用户的键盘输入&#xff0c;后者用来把数据以指定的格式输出到标准控制台或指定的文件对象。无论用户输入什么内容&#xff0c;input() 一律作为字符串对待&#xff0c;必要时可以使用内置函数 int()、…

【SpringBoot教程:从入门到精通】掌握Springboot开发技巧和窍门(四)-Vue项目配置环境、导航栏

主要写前端页面&#xff0c;采用vue框架写页面的导航栏&#xff01;&#xff01;&#xff01; 文章目录 前言 Vue项目配置环境 安装依赖 创建菜单 总结 前言 主要写前端页面&#xff0c;采用vue框架写页面的导航栏&#xff01;&#xff01;&#xff01; Vue项目配置环境 安装…

【算法】分布式共识Paxos

一、引言 在分布式系统中&#xff0c;一致性是至关重要的一个问题。Paxos算法是由莱斯利兰伯特&#xff08;Leslie Lamport&#xff09;在1990年提出的一种解决分布式系统中一致性问题的算法。 二、算法原理 Paxos算法的目标是让一个分布式系统中的多个节点就某个值达成一致。算…

2000-2023年上市公司全要素生产率数据LP法(含原始数据+计算代码+结果)

2000-2023年上市公司全要素生产率数据LP法&#xff08;含原始数据计算代码结果&#xff09; 1、时间&#xff1a;2000-2023年 2、指标&#xff1a;stkcd、year、证券代码、固定资产净额、资产总计、负债合计、支付给职工以及为职工支付的现金、购建固定资产无形资产和其他长期…

Monaco 使用 LinkedEditingRangeProvider

Monaco LinkEdit 功能是指同时修改同样的字符串&#xff0c;例如在编辑 Html 时&#xff0c;修改开始标签时会同时修改闭合标签。Monaco 支持自定义需要一起更新的字符串列表。最终效果如下&#xff1a; 首先&#xff0c;通过 registerLinkedEditingRangeProvider 注册 LinkEd…

关键词查找【Knuth-Morris-Pratt (KMP) 算法】

一个视频让你彻底学懂KMP算法_哔哩哔哩_bilibili KMP算法的核心是利用匹配失败后的信息&#xff0c;尽量减少模式串与主串的匹配次数以达到快速匹配的目的。 第一步&#xff1a;计算模式串(子串)和next[j]数组 模式串 前2位字母的next[j]固定是0 和 1 后续字母的nex[j]&…

生成式AI的发展方向是chat还是Agent探讨

生成式 AI 的发展方向&#xff0c;是 Chat 还是 Agent&#xff1f; 随着生成式AI技术的不断进步&#xff0c;关于其未来发展方向的讨论也愈发激烈。究竟生成式AI的未来是在对话系统&#xff08;Chat&#xff09;中展现智慧&#xff0c;还是在自主代理&#xff08;Agent&#x…

MySQL之触发器和存储过程

1、触发器 触发器简介 触发器&#xff08;trigger&#xff09;是一个特殊的存储过程&#xff0c;它的执行不是由程序调用&#xff0c;也不是手工启动&#xff0c;而是由事件来触 发&#xff0c;比如当对一个表进行操作&#xff08; insert&#xff0c;delete&#xff0c; upda…

js返回一个月的所有天数,用数组表示

直接上代码 import dayjs from dayjs import isSameOrBefore from dayjs/plugin/isSameOrBefore dayjs.extend(isSameOrBefore)function getCurrentMonthDays(month) {const firstDay dayjs().startOf(month);const lastDay dayjs().endOf(month);const allDatesInMonth []…

【C++笔试强训】day05

游游的you 思路 贪心&#xff1a;优先组成 you&#xff0c;最少的字母决定了you的数量。需要注意&#xff1a;如果oo剩下n个&#xff0c;那么相邻oo的个数是n-1个&#xff0c;而不是n/2个。 例如 oooooo oo oo oooo oo 6个o&#xff0c;两两组合有3对&#xff0c;掐头去尾有…

【支持语言模型和视觉语言模型的推理引擎sglang】

介绍 sglang是一个AI推理引擎&#xff0c;是一个专门为大语言模型和视觉语言模型设计的高效服务框架。 就像F1赛车需要顶级发动机一样&#xff0c;大语言模型也需要高效的推理引擎来发挥潜力。 而sglang正是这样一个性能怪兽。 根据LMSys组织的官方公告&#xff0c;最新的s…