使用 JavaScript 检测大写锁定
任何人都有可能在不知不觉中随时打开大写锁定键。在大多数输入法中,用户都能轻易发现不需要的大写锁定,但在使用密码输入法时,问题就不那么明显了。这就导致用户输入的密码不正确,令人苦恼。理想情况下,开发人员可以让用户知道他们的大写锁定键已被激活。
为了检测用户是否打开了键盘的大写锁定功能,我们将使用 KeyboardEvent
的 getModifierState
方法:
document.querySelector('input[type=password]').addEventListener('keyup', function (keyboardEvent) { const capsLockOn = keyboardEvent.getModifierState('CapsLock'); if (capsLockOn) { // Warn the user that their caps lock is on? } });
我以前从未见过 getModifierState
的用法,因此我查阅了 W3C 文档,以发现其他有用的值:
dictionary EventModifierInit : UIEventInit { boolean ctrlKey = false; boolean shiftKey = false; boolean altKey = false; boolean metaKey = false; boolean modifierAltGraph = false; boolean modifierCapsLock = false; boolean modifierFn = false; boolean modifierFnLock = false; boolean modifierHyper = false; boolean modifierNumLock = false; boolean modifierScrollLock = false; boolean modifierSuper = false; boolean modifierSymbol = false; boolean modifierSymbolLock = false; };
在以按键为中心的事件中,getModifierState
提供了大量有关用户键盘的信息。真希望我在职业生涯的早期就知道 getModifier
!
阅读余下内容