轮播图需手动绑定keydown事件监听ArrowLeft/ArrowRight键,容器必须设tabindex="0"以获取焦点,同时调用preventDefault()防止页面滚动;空格键可增强兼容性,移动端应通过用户交互后启用键盘控制。
HTML 轮播图本身不自带键盘控制,必须手动绑定 keydown 事件,监听 ArrowLeft 和 ArrowRight 键码。注意:不要用 keyCode(已废弃),优先用 event.key 判断。
tabindex="0",否则无法获得焦点、收不到键盘事件
event.preventDefault() 防止页面滚动(尤其在 macOS 上按方向键会触发滚动)const carousel = document.querySelector('.carousel');
carousel.tabIndex = 0;
carousel.addEventListener('keydown', (e) => {
if (e.key === 'ArrowLeft') {
prevSlide(); // 你自己的上一页函数
} else if (e.key === 'ArrowRight') {
nextSlide(); // 你自己的下一页函数
}
});
常见原因不是逻辑写错,而是焦点缺失或事件被拦截:
tabindex,浏览器默认不可聚焦,keydown 根本不会触发carousel.focus()
preventDefault() 但没加在正确位置,或在非目标元素上监听部分用户习惯用空格翻页,尤其在无障碍场景中更友好。空格键对应 event.key === ' '(注意是空格字符,不是字符串 'Space')。
preventDefault()
event.shiftKey 实现反向切换(如 Shift+
if (e.key === ' ') {
e.preventDefault();
if (e.shiftKey) {
prevSlide();
} else {
nextSlide();
}
}
手机浏览器也可能触发 keydown(比如外接蓝牙键盘),但多数触摸设备无物理键盘。真正要防的是「伪键盘事件」——某些安卓 WebView 或 iOS Safari 在输入法弹出时误发方向键。
matchMedia('(hover: hover)') 粗略区分是否有悬停能力(间接反映是否大概率有键盘)touchstart 后立刻禁用键盘逻辑,因为可能有混合输入场景(触控+外设)tabindex 就等于没入口,再完整的逻辑也跑不起来。