繁体   English   中英

firefox中的退格键问题

[英]Backspace key issue in firefox

我有一个文本框,并仅使用jquery应用允许使用空格的字母。 它在chrome中工作但是在firefox中,退格键不起作用。

<input type="text" placeholder="" id="id1">

$(function(){
$('#id1').keypress(function (event) {
      if ((event.which >= 65 && event.which < 91) || (event.which > 96 && event.which < 123) || event.which === 32 || event.which===0) {
          return true;
      }
        else {
          event.preventDefault();
      }
 })});

这是Plnkr

浏览器处理退格字符的方式不同。 在Chrome中,backspace永远不会进入keypress事件处理程序,但在Firefox中它确实如此。

如果你添加|| event.which === 8 || event.which === 8你的条件,你将允许退格并返回true,这将使它在Firefox中工作。

编辑 :向上箭头,向下,向左,向右和Tab也无法在Firefox中运行。

var ignoredKeys = [8, 9, 37, 38, 39, 40];

if (ignoredKeys.indexOf(event.which) >=0 || (event.which >= 65 && event.which < 91) || (event.which > 96 && event.which < 123) || event.which === 32 || event.which===0) {
    return true;
} else {
    event.preventDefault();
}

这应该适用于所有[主要]浏览器:

$('#id1').keydown(function (event) {
    if (event.which == 8) {
        // ...
    } else {
        event.preventDefault();
    }
);

注意使用keydown而不是keypress ,这对于它来说是必不可少的。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM