>웹 프론트엔드 >JS 튜토리얼 >JavaScript 및 jQuery에서 화살표 키 입력을 어떻게 캡처할 수 있습니까?

JavaScript 및 jQuery에서 화살표 키 입력을 어떻게 캡처할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-10-29 08:50:021138검색

How Can I Capture Arrow Keystrokes in JavaScript and jQuery?

JS 및 jQuery로 화살표 키 입력 캡처

Javascript 및 jQuery에서 화살표 키에 기능을 바인딩하는 것은 키보드 탐색의 일반적인 요구 사항입니다. jQuery용 js-hotkey 플러그인은 내장 바인드 기능을 확장하지만 화살표 키에 대한 지원은 부족합니다.

이 문제를 해결하기 위한 간단한 해결책은 다음과 같습니다.

<code class="javascript">document.onkeydown = function(e) {
    switch(e.which) {
        case 37: // left
        break;

        case 38: // up
        break;

        case 39: // right
        break;

        case 40: // down
        break;

        default: return; // exit this handler for other keys
    }
    e.preventDefault(); // prevent the default action (scroll / move caret)
};</code>

이 코드는 스위치 문을 사용하여 왼쪽, 위쪽, 오른쪽 및 아래쪽 화살표 키에 대한 키 입력입니다. 각 경우에 원하는 작업을 정의할 수 있습니다.

which 속성을 지원하지 않는 브라우저(예: IE8)의 경우 함수 본문을 다음과 같이 수정하세요.

<code class="javascript">document.onkeydown = function(e) {
    e = e || window.event;
    switch(e.which || e.keyCode) {
        case 37: // left
        break;

        // ...
    }
};</code>

또는 최신 브라우저의 경우 다음 예와 같이 KeyboardEvent.key 속성을 사용하여 화살표 키를 감지할 수 있습니다.

<code class="javascript">document.onkeydown = function(e) {
    switch(e.key) {
        case "ArrowLeft": // left
        break;

        // ...
    }
};</code>

이 코드를 구현하면 함수를 JavaScript의 화살표 키에 쉽게 바인딩할 수 있습니다. 또는 jQuery 애플리케이션.

위 내용은 JavaScript 및 jQuery에서 화살표 키 입력을 어떻게 캡처할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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