찾다
CMS 튜토리얼Word누르다JavaScript: 키보드 이벤트를 캡처하고 이에 반응합니다.

JavaScript: 키보드 이벤트를 캡처하고 이에 반응합니다.

이 기사에서는 JavaScript에서 다양한 키보드 이벤트를 포착하고 응답하는 방법에 대해 설명합니다. 이해하기 쉽도록 몇 가지 실제 사례를 보여 드리겠습니다.

JavaScript는 인터넷의 핵심 기술 중 하나입니다. 대부분의 웹사이트에서 사용되며 플러그인 없이도 모든 최신 웹 브라우저에서 지원됩니다. 이 시리즈에서는 일상적인 JavaScript 개발에 도움이 되는 다양한 팁과 요령에 대해 논의하겠습니다.

JavaScript 개발자는 키보드 이벤트를 처리하고 이를 기반으로 작업을 수행해야 하는 기능을 구현해야 하는 경우가 있습니다. 다행스럽게도 JavaScript는 다양한 유형의 키보드 이벤트를 처리할 수 있는 내장 KeyboardEvent 개체를 제공합니다.

JavaScript의 키보드 이벤트

JavaScript에서 KeyboardEvent 개체는 키 다운, 키 다운, 키 업이라는 세 가지 이벤트를 제공합니다.

키보드의 아무 키나 누르면 다음과 같은 순서로 일련의 이벤트가 발생합니다.

  • 키를 누르세요
  • 버튼
  • 버튼

키보드의 아무 키나 누르면 키 이벤트가 트리거됩니다. 그리고 키를 오랫동안 누르면 키 누르기 이벤트가 반복적으로 발생합니다.

키 이벤트는 주로 인쇄 가능한 문자를 누를 때 발생하며 키 이벤트 후에 발생합니다. 실제로 키 이벤트는 키 이벤트에 의해 생성된 문자를 전달하는 데 사용됩니다. 대부분의 경우 문자가 아닌 키는 키 이벤트를 발생시키지 않습니다. 일부 브라우저에서는 이 이벤트를 지원하지만 웹 표준에서 제거될 예정이므로 이 이벤트에 의존하지 않는 것이 좋습니다.

주요 이벤트는 더 이상 사용되지 않으며 최신 브라우저에서는 단계적으로 폐지됩니다.

마지막으로 키를 놓으면 키 이벤트가 시작됩니다. 기본적으로 keydown과 keydown 이벤트의 조합은 어떤 키를 눌렀는지 나타내는 코드를 제공합니다.

모든 키보드 이벤트는 두 가지 중요한 속성을 제공합니다. keycodekey 属性用按下的字符填充,而 code 属性用字符的物理键位置填充。例如,如果按 a 字符键,则 key 属性将填充为 a,并且 code 属性将填充为 KeyA상수. 그러나 누른 키코드가 반드시 문자와 동일할 필요는 없습니다! 사용자가 Dvorak과 같은 대체 키보드 레이아웃을 설정한 경우 동일한 키 코드를 누르면 다른 문자가 생성됩니다.

위는 JavaScript의 키보드 이벤트에 대한 간략한 개요입니다. 다음 섹션부터 이러한 이벤트가 어떻게 작동하는지 이해하기 위해 실제 사례와 함께 이러한 이벤트에 대해 논의하겠습니다.

keydown 이벤트

이 섹션에서는 keydown 事件如何在 JavaScript 中工作。当按下键盘上的任意键时,会触发 keydown 이벤트가 JavaScript에서 어떻게 작동하는지 알아봅니다.

이벤트는 키보드의 아무 키나 누르면 시작됩니다.

다음 예를 간단히 살펴보겠습니다.

으아아아 keydown보시다시피

이벤트를 청취하기 위한 리스너를 생성했습니다. 아무 키나 누를 때마다 리스너가 호출되고 해당 키의 값과 코드가 콘솔에 기록됩니다. 계속해서 실행하여 어떻게 작동하는지 확인하십시오.

사용자가 ctrl + a 또는 ctrl + A

를 눌렀는지 감지하는 방법을 보여주는 다음 예를 살펴보겠습니다.

으아아아 ctrlKeyKeyboardEvent 对象的一个​​特殊属性,它告诉您在触发 keydown 事件时是否按下了 Ctrl 键。因此,如果 ctrlKey먼저 ctrlKey 이벤트가 발생했을 때 Ctrl

키가 눌렸는지 여부를 알려주는

개체의 특수 속성입니다. 따라서 ctrlKey가 true이면 keyCode 值,如果是 6597,则表示是 a ACtrl 键一起按下。 KeyboardEvent 对象的 keyCodeCtrl 키를 눌렀다는 의미입니다. 다음으로 누른 문자의 keyCode 값을 확인합니다. 65 또는 97이면 a 또는 A

Ctrl

키와 함께 누르세요.

개체의 keyCode 속성은 누른 키의 유니코드 문자 코드를 반환합니다. 마찬가지로

KeyboardEventkeydown 事件。因此,当用户在文本框中输入任何文本时,它会调用 allowOnlyAlphabets 函数。在 allowOnlyAlphabets 函数中,我们根据字母表的有效 Unicode 范围验证了事件对象的 keyCode 属性的值。因此,如果用户按下有效的字母字符,则 allowOnlyAlphabets 函数将返回 true,否则将返回 false 개체의

shiftKey🎜 속성을 사용하면 키 누르기 이벤트 중에 🎜Shift🎜 키가 눌렸는지 여부를 알 수 있습니다. 방아쇠. 🎜 🎜마지막으로 HTML 양식의 입력 필드에 문자만 허용하는 방법을 보여주는 다음 예를 살펴보겠습니다. 🎜 으아아아 🎜위의 예에서는 입력 텍스트 상자에 🎜 이벤트를 정의했습니다. 따라서 사용자가 텍스트 상자에 텍스트를 입력하면 allowOnlyAlphabets 함수가 호출됩니다. allowOnlyAlphabets 함수에서는 유효한 유니코드 알파벳 범위에 대해 이벤트 객체의 keyCode 속성 값을 검증합니다. 따라서 allowOnlyAlphabets 함수는 사용자가 유효한 알파벳 문자를 누르면 true를 반환하고, 그렇지 않으면 false를 반환합니다. 최종 결과는 사용자가 문자 이외의 문자를 입력할 수 없게 된다는 것입니다. 🎜

keyup 事件

在本节中,我们将了解 keyup 事件如何工作。事实上,它的工作原理与 keydown 事件非常相似,唯一的区别是它是在释放按键时触发,而不是在按下按键时触发。

让我们看一下下面的例子。

document.addEventListener('keydown', (event) => {
  var keyValue = event.key;
  var codeValue = event.code;

  console.log("keydown event, keyValue: " + keyValue);
  console.log("keydown event, codeValue: " + codeValue);

}, false);

document.addEventListener('keyup', (event) => {
  var keyValue = event.key;
  var codeValue = event.code;

  console.log("keyup event, keyValue: " + keyValue);
  console.log("keyup event, codeValue: " + codeValue);
}, false);

在上面的示例中,当您按下任意键时,将首先触发 keydown 事件,然后触发 keyup 事件。例如,如果您按 a 键,您应该在控制台上看到以下输出。请务必注意事件的触发顺序。

keydown event, keyValue: a
keydown event, codeValue: KeyA
keyup event, keyValue: a
keyup event, codeValue: KeyA

让我们看一下以下示例,它演示了如何在项目中使用 keyup 事件。

<script>
function getSearchResults(event, element) {
  if (element.value.length > 6) {
    var searchKeyword = element.value;
    // make an AJAX call to fetch search results for "searchKeyword"
  }
}
</script>
<html>
  <body>
    <div>
           <input type="text" onkeyup="return getSearchResults(event, this);">
    </div>
  </body>
</html>

在上面的示例中,我们在输入文本框上定义了 onkeyup 事件。因此,当用户在文本框中输入任何文本时,它都会调用 getSearchResults 函数。在 getSearchResults 函数中,我们将进行 AJAX 调用来获取搜索关键字的搜索结果。这也称为实时搜索,因为它会立即显示搜索结果,而无需刷新整个页面。

重要的 KeyboardEvent 对象属性

在最后一节中,我将总结 KeyboardEvent 对象的重要属性。事实上,我们已经在到目前为止讨论的示例中看到了一些常用的属性,例如 keycode。我们还将在本节中讨论一些其他重要属性。

  • <strong>key</strong>:返回按下的字符。例如,如果按下a字符,则会返回 a
  • <strong>code</strong>:返回字符的物理键码。例如,如果按下a字符,则会返回 KeyA
  • <strong>keyCode</strong>:返回按下的按键的Unicode字符代码。
  • <strong>ctrlKey</strong>:告诉您触发按键事件时是否按下Ctrl键。
  • <strong>altKey</strong>:告诉您触发按键事件时是否按下了Alt键。
  • <strong>shiftKey</strong>:告诉您触发按键事件时是否按下Shift键。
  • <strong>metaKey</strong>:告诉你触发按键事件时是否按下了Meta键。在大多数情况下,Meta 键是键盘上位于 CtrlAlt 键之间的键。
  • <strong>位置</strong>:返回键盘或设备上按键的位置。

如您所见,keyboardEvent 对象提供了各种属性,允许您检测不同的按键。在大多数情况下,您将使用 keydown 事件来检测按下的按键并执行相应的操作。正如我们之前讨论的,您不应该使用 keypress 事件,因为它迟早会被弃用。

结论

今天,我们讨论了如何在 JavaScript 中使用键盘事件以及几个实际示例。

위 내용은 JavaScript: 키보드 이벤트를 캡처하고 이에 반응합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

WordPress.com에서 WordPress.org로 블로그를 이동 하시겠습니까? 많은 초보자는 WordPress.com으로 시작하지만 자신의 한계를 신속하게 인식하고 자체-호스팅 된 WordPress.org 플랫폼으로 전환하려고합니다. 이 단계별 가이드에서는 WordPress.com에서 WordPress.org로 블로그를 올바르게 이동하는 방법을 보여줍니다. WordPress.com에서 WordPress.org로 마이그레이션하는 이유는 무엇입니까? WordPress.com을 사용하면 누구나 계정을 만들 수 있습니다

IFTTT (및 기타)로 WordPress 및 소셜 미디어를 자동화하는 방법IFTTT (및 기타)로 WordPress 및 소셜 미디어를 자동화하는 방법Apr 18, 2025 am 11:27 AM

WordPress 웹 사이트 및 소셜 미디어 계정을 자동화하는 방법을 찾고 계십니까? 자동화를 사용하면 Facebook, Twitter, LinkedIn, Instagram 등에서 WordPress 블로그 게시물 또는 업데이트를 자동으로 공유 할 수 있습니다. 이 기사에서는 IFTTT, Zapier 및 Uncanny Automator를 사용하여 WordPress 및 소셜 미디어를 쉽게 자동화하는 방법을 보여 드리겠습니다. WordPress 및 소셜 미디어를 자동화하는 이유는 무엇입니까? WordPre를 자동화하십시오

WordPress에서 사용자 정의 메뉴 항목 제한을 수정하는 방법WordPress에서 사용자 정의 메뉴 항목 제한을 수정하는 방법Apr 18, 2025 am 11:18 AM

며칠 전, 사용자 중 한 명이 특이한 문제를보고했습니다. 문제는 그가 사용자 정의 메뉴 항목의 한계에 도달한다는 것입니다. 메뉴 항목 제한에 도달 한 후 저장하는 모든 콘텐츠는 전혀 저장되지 않습니다. 우리는이 문제에 대해 들어 본 적이 없으므로 지역 설치를 시도하기로 결정했습니다. 200 개 이상의 메뉴 항목이 생성되고 저장되었습니다. 효과는 매우 좋습니다. 100 개의 항목을 드롭 다운 목록으로 옮기고 잘 저장하십시오. 그런 다음 서버와 관련이 있다는 것을 알았습니다. 추가 연구 후에, 다른 많은 사람들도 같은 문제를 겪은 것으로 보입니다. 더 깊이 파고 들자, 우리는이 문제를 강조한 Trac 티켓 (#14134)을 발견했습니다. 매우 읽으십시오

WordPress에서 사용자 정의 분류법에 맞춤형 메타 필드를 추가하는 방법WordPress에서 사용자 정의 분류법에 맞춤형 메타 필드를 추가하는 방법Apr 18, 2025 am 11:11 AM

WordPress의 사용자 정의 분류 체계에 맞춤형 메타 필드를 추가해야합니까? 사용자 정의 분류법을 사용하면 카테고리 및 태그 외에 컨텐츠를 구성 할 수 있습니다. 때로는 다른 필드를 추가하여 설명하는 것이 유용합니다. 이 기사에서는 그들이 만든 분류법에 다른 메타 엘드를 추가하는 방법을 보여 드리겠습니다. 사용자 정의 메타 필드는 언제 커스텀 분류 체계에 추가해야합니까? WordPress 사이트에서 새 콘텐츠를 만들 때 두 개의 기본 분류법 (카테고리 및 태그)을 사용하여 구성 할 수 있습니다. 일부 웹 사이트는 사용자 정의 분류법 사용의 혜택을받습니다. 이를 통해 다른 방식으로 내용을 정렬 할 수 있습니다. 예를 들어,

Windows Live Writer를 사용하여 WordPress에 원격으로 게시하는 방법Windows Live Writer를 사용하여 WordPress에 원격으로 게시하는 방법Apr 18, 2025 am 11:02 AM

Windows Live Writer는 데스크탑에서 WordPress 블로그에 직접 게시물을 게시 할 수있는 다양한 도구입니다. 즉, 블로그를 전혀 업데이트하려면 WordPress 관리자 패널에 로그인 할 필요가 없습니다. 이 튜토리얼에서는 Windows Live Writer를 사용하여 WordPress 블로그에 데스크톱 게시를 활성화하는 방법을 보여 드리겠습니다. WordPress에서 Windows Live Writer를 설정하는 방법 1 단계 : WordPR에서 Windows Live Writer를 사용합니다

WordPress Visual Editor에서 흰색 텍스트 및 누락 된 버튼을 수정하는 방법WordPress Visual Editor에서 흰색 텍스트 및 누락 된 버튼을 수정하는 방법Apr 18, 2025 am 10:52 AM

최근에 사용자 중 한 명이 매우 이상한 설치 문제를보고했습니다. 게시물을 쓸 때는 글을 쓰는 것을 볼 수 없습니다. 게시물 편집기의 텍스트는 흰색이기 때문입니다. 또한 모든 시각적 편집기 버튼이없고 Visual에서 HTML로 전환 할 수있는 기능도 작동하지 않습니다. 이 기사에서는 WordPress Visual Editor에서 흰색 텍스트 및 누락 된 버튼 문제를 해결하는 방법을 보여줍니다. 초보자주의 사항 : 다른 웹 사이트의 스크린 샷에서 볼 수있는 숨겨진 버튼을 찾고 있다면 주방 싱크대를 찾고있을 수 있습니다. 밑줄, 단어에서 복사 등과 같은 다른 옵션을 보려면 주방 싱크 아이콘을 클릭해야합니다.

WordPress에서 사용자 이메일에 아바타를 표시하는 방법WordPress에서 사용자 이메일에 아바타를 표시하는 방법Apr 18, 2025 am 10:51 AM

WordPress의 사용자 이메일에 아바타를 표시 하시겠습니까? Gravatar는 사용자의 이메일 주소를 온라인 아바타에 연결하는 네트워크 서비스입니다. WordPress는 주석 섹션에 방문자의 프로필 사진을 자동으로 표시하지만 사이트의 다른 영역에 추가 할 수도 있습니다. 이 기사에서는 WordPress의 사용자 이메일에 아바타를 표시하는 방법을 보여 드리겠습니다. Gravatar 란 무엇이며 왜 표시해야합니까? Gravatar는 전 세계적으로 인정 된 아바타를 나타내며 사람들이 이미지를 이메일 주소에 연결할 수 있습니다. 웹 사이트가 지원되는 경우

WordPress에서 기본 매체 업로드 위치를 변경하는 방법WordPress에서 기본 매체 업로드 위치를 변경하는 방법Apr 18, 2025 am 10:47 AM

WordPress에서 기본 미디어 업로드 위치를 변경 하시겠습니까? 미디어 파일을 다른 폴더로 옮기면 웹 사이트 속도와 성능을 향상시키고 백업을 더 빨리 만들 수 있습니다. 또한 자신에게 가장 적합한 방식으로 파일을 정리할 수있는 자유를 제공합니다. 이 기사에서는 WordPress에서 기본 미디어 업로드 위치를 변경하는 방법을 보여줍니다. 기본 매체 업로드 위치를 변경하는 이유는 무엇입니까? 기본적으로 WordPress는 모든 이미지 및 기타 미디어 파일을/wp-content/uploads/폴더에 저장합니다. 이 폴더에서는 여러 해 및 몇 달의 어린이를 찾을 수 있습니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.