为了账号安全,请及时绑定邮箱和手机立即绑定

如何为DIV赋予键盘焦点并为其附加键盘事件处理程序?

如何为DIV赋予键盘焦点并为其附加键盘事件处理程序?

忽然笑 2019-11-29 10:05:30
我正在构建一个应用程序,我希望该应用程序能够单击由DIV表示的矩形,然后使用键盘通过列出键盘事件来移动该DIV。我可以在DIV级别上监听键盘事件,而不是在文档级别上使用事件监听器监听这些键盘事件,也许可以通过将其作为键盘焦点?这是一个简化的示例来说明问题:<html><head></head><body><div id="outer" style="background-color:#eeeeee;padding:10px">outer   <div id="inner" style="background-color:#bbbbbb;width:50%;margin:10px;padding:10px;">   want to be able to focus this element and pick up keypresses   </div></div><script language="Javascript">function onClick(){    document.getElementById('inner').innerHTML="clicked";    document.getElementById('inner').focus();}//this handler is never calledfunction onKeypressDiv(){    document.getElementById('inner').innerHTML="keypress on div";}function onKeypressDoc(){    document.getElementById('inner').innerHTML="keypress on doc";}//install event handlersdocument.getElementById('inner').addEventListener("click", onClick, false);document.getElementById('inner').addEventListener("keypress", onKeypressDiv, false);document.addEventListener("keypress", onKeypressDoc, false);</script></body></html>在单击内部DIV时,我尝试为其指定焦点,但随后的键盘事件总是在文档级别而不是在DIV级别事件监听器上拾取。我是否只需要实现特定于应用程序的键盘焦点概念?我应该补充一点,我只需要这个就可以在Firefox中工作。javascript 事件 键盘
查看完整描述

3 回答

?
跃然一笑

TA贡献1826条经验 获得超6个赞

保罗的答案很好,但您也可以使用contentEditable,如下所示:


document.getElementById('inner').contentEditable=true;

document.getElementById('inner').focus();

在某些情况下可能更可取。


查看完整回答
反对 回复 2019-11-29
  • 3 回答
  • 0 关注
  • 460 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号