>웹 프론트엔드 >JS 튜토리얼 >JavaScript에서 화살표 키 누르기를 감지하는 방법: onkeypress가 작동하지 않는 이유와 onkeydown 솔루션

JavaScript에서 화살표 키 누르기를 감지하는 방법: onkeypress가 작동하지 않는 이유와 onkeydown 솔루션

DDD
DDD원래의
2024-11-16 18:37:03265검색

How to Detect Arrow Key Presses in JavaScript: Why onkeypress Doesn't Work and the onkeydown Solution

JavaScript에서 화살표 키 누름 감지: 종합 가이드

키 누름 감지는 웹 개발, 특히 대화형 컨트롤을 생성할 때 일반적인 작업입니다. 대부분의 키는 onkeypress 이벤트 리스너를 사용하여 정확하게 감지할 수 있지만 화살표 키는 독특한 문제를 야기합니다. 이 기사에서는 onkeypress를 사용하여 화살표 키를 감지할 수 없는 이유를 살펴보고 JavaScript에서 화살표 키 누르기를 캡처하는 간단한 솔루션을 제공합니다.

화살표 키 딜레마

onkeypress를 사용하여 키 누르기를 감지하면 작동합니다. 대부분의 키에 완벽하게 적용됩니다. 그러나 화살표 키(왼쪽, 위쪽, 오른쪽, 아래쪽)는 onkeypress 이벤트를 트리거하지 않습니다. 이는 브라우저가 화살표 키를 다르게 처리하여 기본적으로 스크롤 동작을 시작하기 때문입니다.

해결책: onkeydown 사용

화살표 키 누름을 감지하려면 onkeypress 대신 onkeydown 이벤트 리스너를 사용해야 합니다. onkeydown 이벤트는 화살표 키를 포함하여 키를 누를 때마다 발생합니다. 다음은 onkeydown을 사용하는 코드 조각의 업데이트된 버전입니다.

function checkKey(e) {
    var event = window.event ? window.event : e;
    console.log(event.keyCode);
}

화살표 키 키코드

특정 화살표 키를 식별하려면 해당 키코드를 사용할 수 있습니다.

  • 왼쪽: 37
  • 위: 38
  • 오른쪽: 39
  • 아래: 40

event.keyCode를 이 값과 비교하면 어떤 화살표 키를 눌렀는지 쉽게 알 수 있습니다.

위 내용은 JavaScript에서 화살표 키 누르기를 감지하는 방법: onkeypress가 작동하지 않는 이유와 onkeydown 솔루션의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.