이 기사에서는 JavaScript에서 다양한 키보드 이벤트를 포착하고 응답하는 방법에 대해 설명합니다. 이해하기 쉽도록 몇 가지 실제 사례를 보여 드리겠습니다.
JavaScript는 인터넷의 핵심 기술 중 하나입니다. 대부분의 웹사이트에서 사용되며 플러그인 없이도 모든 최신 웹 브라우저에서 지원됩니다. 이 시리즈에서는 일상적인 JavaScript 개발에 도움이 되는 다양한 팁과 요령에 대해 논의하겠습니다.
JavaScript 개발자는 키보드 이벤트를 처리하고 이를 기반으로 작업을 수행해야 하는 기능을 구현해야 하는 경우가 있습니다. 다행스럽게도 JavaScript는 다양한 유형의 키보드 이벤트를 처리할 수 있는 내장 KeyboardEvent
개체를 제공합니다.
JavaScript의 키보드 이벤트
JavaScript에서 KeyboardEvent
개체는 키 다운, 키 다운, 키 업이라는 세 가지 이벤트를 제공합니다.
키보드의 아무 키나 누르면 다음과 같은 순서로 일련의 이벤트가 발생합니다.
- 키를 누르세요
- 버튼
- 버튼
키보드의 아무 키나 누르면 키 이벤트가 트리거됩니다. 그리고 키를 오랫동안 누르면 키 누르기 이벤트가 반복적으로 발생합니다.
키 이벤트는 주로 인쇄 가능한 문자를 누를 때 발생하며 키 이벤트 후에 발생합니다. 실제로 키 이벤트는 키 이벤트에 의해 생성된 문자를 전달하는 데 사용됩니다. 대부분의 경우 문자가 아닌 키는 키 이벤트를 발생시키지 않습니다. 일부 브라우저에서는 이 이벤트를 지원하지만 웹 표준에서 제거될 예정이므로 이 이벤트에 의존하지 않는 것이 좋습니다.
주요 이벤트는 더 이상 사용되지 않으며 최신 브라우저에서는 단계적으로 폐지됩니다.마지막으로 키를 놓으면 키 이벤트가 시작됩니다. 기본적으로 keydown과 keydown 이벤트의 조합은 어떤 키를 눌렀는지 나타내는 코드를 제공합니다.
모든 키보드 이벤트는 두 가지 중요한 속성을 제공합니다. key
和 code
。 key
属性用按下的字符填充,而 code
属性用字符的物理键位置填充。例如,如果按 a
字符键,则 key 属性将填充为 a
,并且 code
属性将填充为 KeyA
상수. 그러나 누른 키코드가 반드시 문자와 동일할 필요는 없습니다! 사용자가 Dvorak과 같은 대체 키보드 레이아웃을 설정한 경우 동일한 키 코드를 누르면 다른 문자가 생성됩니다.
위는 JavaScript의 키보드 이벤트에 대한 간략한 개요입니다. 다음 섹션부터 이러한 이벤트가 어떻게 작동하는지 이해하기 위해 실제 사례와 함께 이러한 이벤트에 대해 논의하겠습니다.
keydown
이벤트
이 섹션에서는 keydown
事件如何在 JavaScript 中工作。当按下键盘上的任意键时,会触发 keydown
이벤트가 JavaScript에서 어떻게 작동하는지 알아봅니다.
다음 예를 간단히 살펴보겠습니다.
으아아아
keydown
보시다시피
사용자가 ctrl + a 또는 ctrl + A
를 눌렀는지 감지하는 방법을 보여주는 다음 예를 살펴보겠습니다.
으아아아
ctrlKey
是 KeyboardEvent
对象的一个特殊属性,它告诉您在触发 keydown
事件时是否按下了 Ctrl 键。因此,如果 ctrlKey
먼저 ctrlKey
는 이벤트가 발생했을 때 Ctrl
개체의 특수 속성입니다. 따라서 ctrlKey
가 true이면 keyCode
值,如果是 65
或 97
,则表示是 a 或 A 与 Ctrl 键一起按下。 KeyboardEvent
对象的 keyCode
Ctrl 키를 눌렀다는 의미입니다.
다음으로 누른 문자의 keyCode
값을 확인합니다. 65
또는 97
이면 a 또는 A
키와 함께 누르세요.
개체의keyCode
속성은 누른 키의 유니코드 문자 코드를 반환합니다. 마찬가지로 KeyboardEventkeydown
事件。因此,当用户在文本框中输入任何文本时,它会调用 allowOnlyAlphabets
函数。在 allowOnlyAlphabets
函数中,我们根据字母表的有效 Unicode 范围验证了事件对象的 keyCode
属性的值。因此,如果用户按下有效的字母字符,则 allowOnlyAlphabets
函数将返回 true
,否则将返回 false
개체의
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
对象的重要属性。事实上,我们已经在到目前为止讨论的示例中看到了一些常用的属性,例如 key
和 code
。我们还将在本节中讨论一些其他重要属性。
-
<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 键是键盘上位于 Ctrl 和 Alt 键之间的键。 -
<strong>位置</strong>
:返回键盘或设备上按键的位置。
如您所见,keyboardEvent
对象提供了各种属性,允许您检测不同的按键。在大多数情况下,您将使用 keydown
事件来检测按下的按键并执行相应的操作。正如我们之前讨论的,您不应该使用 keypress
事件,因为它迟早会被弃用。
结论
今天,我们讨论了如何在 JavaScript 中使用键盘事件以及几个实际示例。
위 내용은 JavaScript: 키보드 이벤트를 캡처하고 이에 반응합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

예, WordPress는 전자 상거래에 매우 적합합니다. 1) WooCommerce 플러그인을 사용하면 WordPress는 완전히 기능적인 온라인 상점이 될 수 있습니다. 2) 성능 최적화 및 보안에주의를 기울이십시오. 캐시 및 보안 플러그인의 정기적 인 업데이트 및 사용이 핵심입니다. 3) WordPress는 사용자 경험을 향상시키고 SEO를 크게 최적화하기위한 풍부한 사용자 정의 옵션을 제공합니다.

웹 사이트를 Yandex Webmaster 도구에 연결 하시겠습니까? Google Search Console, Bing 및 Yandex와 같은 웹 마스터 도구를 사용하면 웹 사이트를 최적화하고 트래픽을 모니터링하고 Robots.txt를 관리하고 웹 사이트 오류 확인 등을 확인할 수 있습니다. 이 기사에서는 WordPress 웹 사이트를 Yandex 웹 마스터 도구에 추가하여 검색 엔진 트래픽을 모니터링하는 방법을 공유합니다. Yandex는 무엇입니까? Yandex는 Google 및 Bing과 유사한 러시아에 기반을 둔 인기있는 검색 엔진입니다. Yandex에서 탁월 할 수 있습니다

WordPress에서 HTTP 이미지 업로드 오류를 수정해야합니까? 이 오류는 WordPress에서 컨텐츠를 만들 때 특히 실망 스러울 수 있습니다. 일반적으로 내장 된 WordPress 미디어 라이브러리를 사용하여 이미지 또는 기타 파일을 CMS에 업로드 할 때 발생합니다. 이 기사에서는 WordPress에서 HTTP 이미지 업로드 오류를 쉽게 수정하는 방법을 보여줍니다. WordPress 미디어 업로드 중에 HTTP 오류의 이유는 무엇입니까? WordPress 미디어 업 로더를 사용하여 파일을 WO에 업로드하려고 할 때

최근에 독자 중 한 명이 WordPress 사이트의 미디어 추가 버튼이 갑자기 작동을 멈췄다 고보고했습니다. 이 고전적인 편집기 문제는 오류 나 경고가 표시되지 않으므로 사용자가 "미디어 추가"버튼이 작동하지 않는 이유를 알지 못합니다. 이 기사에서는 작동하지 않는 WordPress에서 미디어 추가 버튼을 쉽게 수정하는 방법을 보여줍니다. WordPress "Media Add"버튼이 작동하지 않도록 원인은 무엇입니까? 오래된 Classic WordPress 편집기를 사용하는 경우 미디어 추가 버튼을 사용하면 이미지, 비디오 등을 블로그 게시물에 삽입 할 수 있습니다.

WordPress 웹 사이트에서 쿠키를 사용하는 방법을 알고 싶습니까? 쿠키는 사용자 브라우저에 임시 정보를 저장하는 데 유용한 도구입니다. 이 정보를 사용하여 개인화 및 행동 타겟팅을 통해 사용자 경험을 향상시킬 수 있습니다. 이 Ultimate Guide에서는 전문가처럼 WordPressCookies를 설정, 받기 및 삭제하는 방법을 보여 드리겠습니다. 참고 : 이것은 고급 튜토리얼입니다. HTML, CSS, WordPress 웹 사이트 및 PHP에 능숙해야합니다. 쿠키는 무엇입니까? 쿠키는 사용자가 웹 사이트를 방문 할 때 생성 및 저장됩니다.

WordPress 웹 사이트에서 "429 너무 많은 요청"오류가 표시됩니까? 이 오류 메시지는 사용자가 웹 사이트 서버에 너무 많은 HTTP 요청을 보내고 있음을 의미합니다. 이 오류는 오류의 원인을 찾기가 어렵 기 때문에 매우 실망 스러울 수 있습니다. 이 기사에서는 "WordPress429ToOmanyRequests"오류를 쉽게 수정하는 방법을 보여줍니다. WordPress429에 대한 요청이 너무 많은 원인은 무엇입니까? "429toomanyRequests"오류의 가장 일반적인 원인은 사용자, 봇 또는 스크립트가 웹 사이트로 이동하려고 시도하기 때문입니다.

WordPressCanhandlelArgeWebsites와 함께 확보 및 최적으로 최적화 된 경우 1) USECACHINGTOREDUCESERVERLOWN.2) 최적화 최적화

WordPress는 매우 사용자 정의되어 있으며 다양한 유연성과 사용자 정의 가능성을 제공합니다. 1) 테마 및 플러그인 생태계를 통해 2) 프론트 엔드 개발에 RESTAPI를 사용하십시오. 그러나 사용자 정의에는 PHP, JavaScript, CSS 등과 같은 마스터 링 기술이 필요하며 잠재적 인 문제를 피하기 위해 성능 최적화 및 플러그인 선택에주의를 기울여야합니다.


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

드림위버 CS6
시각적 웹 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

Dreamweaver Mac版
시각적 웹 개발 도구