首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么键/键不是在“选择”上触发的?

为什么键/键不是在“选择”上触发的?
EN

Stack Overflow用户
提问于 2018-04-03 01:20:52
回答 2查看 910关注 0票数 4

当客户端在select选项之间移动时,为什么不触发键盘事件?还有其他的活动吗?

如何复制:

  • 集中注意select元素。
  • 打开选择选项。
  • 使用键盘(上/下)箭头移动选择选项。

结果:当您使用上/下键盘键移动这些选项时,没有发送任何事件。

HTML

代码语言:javascript
复制
<!-- The second value will be selected initially -->
<select name="text"> <!--Supplement an id here instead of using 'text'-->
  <option value="value1">Value 1</option> 
  <option value="value2" selected>Value 2</option>
  <option value="value3">Value 3</option>
</select>

JS

代码语言:javascript
复制
function onkeyEvent(evt ){
    console.log(evt);
}
            window.addEventListener('keyup', onkeyEvent, true);
            window.addEventListener('keydown', onkeyEvent, true);
            window.addEventListener('keypress', onkeyEvent, true);

只有在选择了一个选项之后,才会触发Change事件,而不是当客户端正在选择时(通过选项移动),所以我不会接受它作为一个答案。

EN

回答 2

Stack Overflow用户

发布于 2022-06-03 23:18:34

我能够使用这样的setTimeOut来解决这个问题:

代码语言:javascript
复制
$("selector").on('keydown', (ev)=> { 
    if (ev.key == "Enter") {
        setTimeout(() => {
            $("selector_to_focus").focus();            
        }, 100);
    } 
});

在我的例子中,时间执行会导致输入在按回车键后跳两次。

票数 0
EN

Stack Overflow用户

发布于 2018-04-03 01:50:11

正如其他人所提到的,要从<select>元素获取关键事件,可以向元素的change事件中添加事件侦听器。

票数 -2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49620872

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档