如何通过js调用工控机(Windows)虚拟键盘

1. 需求背景

在工控机触摸屏中,通过浏览器web端进行表单输入,当聚焦表单输入框并不会出现虚拟键盘进行输入。

解决方式:

  1. 使用第三方npm虚拟键盘插件引入使用
  2. 使用js调用系统自带的虚拟键盘
  3. 使用快捷键Win+Ctrl+O打开关闭

本文介绍下第二种方式进行操作。

2. 实现方式

在网页中通过js调用Windows上本地的exe程序,通过修改 Windows 注册表来使用 window.open 打开键盘,实际上是在设置一个自定义的 URL 协议(如 "keyboardProtocol")与键盘应用程序(通常是系统自带的屏幕键盘)相关联。当用户在网页中点击一个链接或使用 JavaScript 打开一个 "keyboardProtocol" URL 时,这将触发屏幕键盘的打开。

  1. 找出虚拟键盘的可执行文件路径,如:C:\Windows\system32\osk.exe
  2. 编写注册文件reg文件
js 复制代码
Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\keyboard] // 定义自定义 URL 协议的关键部分
@="keyboardProtocol"  // 自定义的 URL 协议名称
"URL Protocol"="keyboardProtocol" // 确保了系统知道这是一个自定义协议

[HKEY_CLASSES_ROOT\keyboard\DefaultIcon] // 定义了当用户在资源管理器或文件浏览器中双击与 "keyboardProtocol" 相关联的文件时显示的图标
@="C:\\windows\\system32\\osk.exe" // 屏幕键盘应用程序的路径

[HKEY_CLASSES_ROOT\keyboard\shell]  // 定义了如何与该协议交互

[HKEY_CLASSES_ROOT\keyboard\shell\open] // 定义了当用户右键点击与 "keyboardProtocol" 相关联的文件或文件夹并选择"打开"时发生的行为

[HKEY_CLASSES_ROOT\keyboard\shell\open\command] // 定义了如何执行与 "open" 操作相关联的操作
@="\"C:\\windows\\system32\\osk.exe\""
  1. 双击执行
  2. js中调用
js 复制代码
// 方法一
 window.location.href="keyboard://";
//or
window.open("keyboard://");

</script>
<!-- 方法二-->
<a href="keyboard://">打开应用程序</a>

3. 总结

该方法依赖于Windows系统自带的虚拟键盘,不适用于其他操作系统。

提供了一种通过JavaScript调用Windows系统自带的虚拟键盘的方法,解决在工控机触摸屏的web浏览器中进行表单输入时调用虚拟键盘的问题。

相关推荐
崔庆才丨静觅6 小时前
hCaptcha 验证码图像识别 API 对接教程
前端
passerby60617 小时前
完成前端时间处理的另一块版图
前端·github·web components
掘了7 小时前
「2025 年终总结」在所有失去的人中,我最怀念我自己
前端·后端·年终总结
崔庆才丨静觅7 小时前
实用免费的 Short URL 短链接 API 对接说明
前端
崔庆才丨静觅8 小时前
5分钟快速搭建 AI 平台并用它赚钱!
前端
崔庆才丨静觅8 小时前
比官方便宜一半以上!Midjourney API 申请及使用
前端
Moment8 小时前
富文本编辑器在 AI 时代为什么这么受欢迎
前端·javascript·后端
崔庆才丨静觅8 小时前
刷屏全网的“nano-banana”API接入指南!0.1元/张量产高清创意图,开发者必藏
前端
剪刀石头布啊8 小时前
jwt介绍
前端
爱敲代码的小鱼9 小时前
AJAX(异步交互的技术来实现从服务端中获取数据):
前端·javascript·ajax