How can I disabling backspace key press on all browsers?

后端 未结 9 1125
一向
一向 2020-12-15 10:01

I\'m trying to disable the backspace button on an order page in all cases except when a textarea or text input is an active element to prevent users from accidentally backin

9条回答
  •  挽巷
    挽巷 (楼主)
    2020-12-15 10:51

    I think you're overcomplicating that. Rather than checking for an active element, find the event target instead. This should give you the information you need. It's also better to use keydown rather than keypress when there is no visible character. Finally, it's better to use e.preventDefault() for better granularity.

    $(document).keydown(function(e) {
        var nodeName = e.target.nodeName.toLowerCase();
    
        if (e.which === 8) {
            if ((nodeName === 'input' && e.target.type === 'text') ||
                nodeName === 'textarea') {
                // do nothing
            } else {
                e.preventDefault();
            }
        }
    });
    

    NB I could have done this the other way round, rather than an empty if block and all the code going in the else block, but I think this is more readable.

提交回复
热议问题