使用javascript或jquery在文本字段中进行十进制验证

Decimal validation in the textfield using javascript or jquery

本文关键字:十进制 验证 字段 文本 javascript jquery 使用      更新时间:2023-09-26

i想要验证keyup事件中的文本字段。

在字段中,它应该接受货币类型的十进制,如

(12.23)(.23)(0.26)(5.09)(6.00)

如果我输入了一些错误的值,那么它应该返回到上一个值并删除错误的

我认为这样的东西可能是的最佳选择

var isValidCurrency = function(str) {
  var num = parseFloat(str);
  return !Number.isNaN(num) && num.toFixed(2).toString() === str;
};

一些测试

isValidCurrency("1234.56");   // true
isValidCurrency("1234.565");  // false
isValidCurrency("1234");      // false
isValidCurrency("foo");       // false

您可以使用以下Regex

val = "2.13"
if (!val.match(/^('d{0,2})('.'d{2})$/)) {
    alert("wrong");
} else {
    alert("right");
}

http://jsfiddle.net/rtL3J/1/

编辑

请注意,如果点(.)前面的数字长度限制为两,则代码有效代码为

^('d{0,2})('.'d{2})$

否则,如果没有限制,则仅从代码中删除2,即

^('d{0,})('.'d{2})$

试试这个:

function evMoneyFormat(evt) {
    //--- only accepts accepts number and 2 decimal place value
    var theEvent = evt || window.event;
    var key = theEvent.keyCode || theEvent.which;
    key = String.fromCharCode(key);
    var regex = /^[0-9]{1,14}'.[0-9]{0,2}$/; // number with 2 decimal places
    if (!regex.test(key)) {
        theEvent.returnValue = false;
        //--- this prevents the character from being displayed
        if (theEvent.preventDefault) theEvent.preventDefault();
    }
}

控制:

<input type='text' onkeyup='evMoneyFormat( e );'>

尝试以下代码

function validateDecimal(num){
   var dotPosition=num.indexOf(".");
   if(dotPosition=="-1"){
      document.getElementById('cost').value= num+".00"
   }
}

并且在html 中

<input type="text" id='cost' onkeyup="validateDecimal(this.value)" />