将键盘输入保存到变量中

时间:2012-08-14 10:57:31

标签: javascript firefox-addon xul

我编写了一个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);
  }

1 个答案:

答案 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 = "";
    ...
  }
}

文档:event.charCode