FireFox中的Javascript错误不在IE和Chrome中

时间:2012-06-29 04:57:21

标签: javascript internet-explorer validation firefox google-chrome

我使用以下函数进行十进制验证。文本框只允许输入数字和。(点)符号。它在IE和Chrome中工作正常。我的问题是我得到事件未定义错误< /strong>。如何解决这个问题?我有很多文本框验证。所以我创建了十进制验证,就像其常见一样,

//Call the Function
                             $('.decimalValidate').live('keypress',function(){
                                  var decimalid=$(this).attr("id");
                                  var decimalval=$('#'+decimalid).val();
                                  var decimalvalidate=ApplyDecimalFilter(decimalval);
                                  if(decimalvalidate == false)
                                  return false;
                             });

//十进制验证的功能。它只允许一个。 symbol.everything在IE和Chrome上运行良好

function ApplyDecimalFilter(id)
    {
        try {
              return NewDecimalFilter(id, event);

        } catch (e) {
            alert(e.message);
        }
    }

function NewDecimalFilter(o, event) {

        if (event.keyCode > 47 && event.keyCode < 58) {
            return true;
        }
        if ((event.keyCode == 8 || event.keyCode == 46) && o.indexOf('.') == -1)  {
            return true;
        }
        return false;
    }

我在文本框中使用此decimalValidate类,如as,

input type="text" id="InputLoanAmount" class="decimalValidate" style="width:100px"

1 个答案:

答案 0 :(得分:5)

在Firefox中,event不是全局的。 window.eventundefined。您需要将事件作为参数传递。顺便说一句,如果您使用jQuery&gt; = 1.7,则应使用.on而不是.live

$('.decimalValidate').live('keypress', function (e) {
    var decimalid = $(this).attr("id");
    var decimalval = $('#' + decimalid).val();
    var decimalvalidate = ApplyDecimalFilter(decimalval, e);
    if (decimalvalidate == false) return false;
});

function ApplyDecimalFilter(id, event) {
    try {
        return NewDecimalFilter(id, event);

    } catch (e) {
        alert(e.message);
    }
}

The live demo