我编写了一个Firefox扩展程序,它从条形码标签扫描程序获取输入,调用页面并将其写入字段。扫描仪被编程为在读取标签后发送击键。我在窗口对象上添加了一个事件,该事件正在侦听 CTRL K 。我的问题是关注文本框,当它丢失时它不起作用。我的问题是:是否可以在不使用文本框元素的情况下获取扫描标签的值?扫描仪输入通过键盘界面输入。
BrowserOverlay.xul
:
<window id="main-window">
<script type="application/x-javascript">
window.addEventListener("keydown", barcodeInit, false);
function sel(){
var textbox = document.getElementById("editIndex");
textbox.focus();
}
</script>
<hbox>
<spacer flex="1"/>
<textbox id="editIndex" value="" size="1" maxlength="25" oncommand="sel()" />
<statusbar id="status-bar" class="chromeclass-status">
<statusbarpanel label="Barcode AddOn" class="statusbarpanel-iconic"
onclick="openPreferences('barcodePane');" align="left"
src="chrome://topas/content/images/icon18.png" />
</statusbar>
</hbox>
当我收到文本框内容时,我正在调用openURI
方法在实际窗口中打开页面并post data to it。
BrowserOverlay.js
:
if (event.ctrlKey && pressedKey == prefKey ){
if(typeof editIndex != "undefined"){
var dataString = "barcodeValue=" + editIndex;
immidiate = true;
document.getElementById("editIndex").value = "";
window.loadURI(stringURL, null, dataString, false);
}
答案 0 :(得分:1)
您可以通过侦听keypress
对象上的window
事件来接收按键 - 只要浏览器窗口被聚焦,无论窗口的哪个元素处于活动状态,您都可以获得它们。沿着这些方向:
var data = "";
window.addEventListener("keypress", processKeyPress, false);
window.addEventListener("keydown", processKeyDown, false);
function processKeyPress(event)
{
data += String.fromCharCode(event.charCode);
}
function processKeyDown(event)
{
if (event.ctrlKey && event.keyCode == prefKey)
{
var dataString = "barcodeValue=" + data;
data = "";
...
}
}