JavaScript Decimal Place Restriction With RegEx

前端 未结 7 826
北恋
北恋 2020-12-06 12:23

I have some client-side validation against a text box, which only allows numbers up to two decimal places with no other input.

This script was a basis for entering n

相关标签:
7条回答
  • 2020-12-06 12:48

    Do you really want to do this with a regex?

    function valid(f) {
        if(isNaN(f)){return false;}
        return 100 * f == parseInt(100*f,10);
    }
    
    0 讨论(0)
  • 2020-12-06 12:50

    gs: This is very close, but the line

    f.value = f.value.replace(/[^\d\.]/g, "");
    

    Doesn't actually appear to work. In fact I lose focus of the text box for some reason. Although perhaps it's my code ;)

    0 讨论(0)
  • 2020-12-06 12:53

    The . character has special meaning in RegEx so needs escaping.

    /^(?:\d*\.\d{1,2}|\d+)$/
    

    This matches 123.45, 123.4, 123 and .2, .24 but not emtpy string, 123., 123.456

    0 讨论(0)
  • 2020-12-06 12:59

    . means in RegEx: any character, you have to put a backslash infront of it. \.

    This would be better:

    /^\d+(\.\d{0,2})?$/
    

    Parts I included:

    • You need at least 1 number in front of the dot. If you don't want this, replace + with * but then also empty strings would be matched.
    • If you have decimal values you need the dot in front.
    • There shouldn't be anything after the number, $ stands for the end of the input.

    and for the replacing part you should also include the dot

    f.value.replace(/[^\d\.]/g, "")
    

    Edit:

    If it's for the live validation of inputs, why don't you just either intercept keyevents and test for their validity (by creating the string in memory) or just delete the last character in the field?

    0 讨论(0)
  • 2020-12-06 13:12

    Regex

    /^\d+(\.\d{1,2})?$/
    

    JavaScript

    function valid(f) {
      if(!f.value) { // Test if text field is empty
        f.value = 0; // Initialize value to 0
        console.log("Valid number"); // Let user know input is OK
      } else if (!/^\d+(\.\d{1,2})?$/.test(f.value)) { // Test regex
        f.value = ""; // Empty the text box
        console.error("invalid number"); // Let user know input is not OK
      } else {
        console.log("Valid number"); // Let user know input is OK
      }
    }
    
    document.getElementById("testbutton").addEventListener( // Add event listener to button
      "click",
      valid.bind( // Bind the text field to the `value` function
        this, 
        document.getElementById("testfield")
      )
    );
    <input id="testfield" value="15.1" />
    <button id="testbutton">Test expression</button>


    Explanation

    1. / / : the beginning and end of the expression
    2. ^ : whatever follows should be at the beginning of the string you're testing
    3. \d+ : there should be at least one digit
    4. ( )? : this part is optional
    5. \. : here goes a dot
    6. \d{1,2} : there should be between one and five digits here
    7. $ : whatever precedes this should be at the end of the string you're testing

    Tip

    You can use regexr.com or regex101.com for testing regular expressions directly in the browser!

    0 讨论(0)
  • 2020-12-06 13:12

    If we need to validate numric value in a textbox where we want to prevent more than one decimals(e.g 2..3,.2. etc)

    Below is the Javascript funcion for that.

     if (MoreThanOnePoint(document.getElementById("txtNoofHrs").value) == false) {
         alert("Please enter one decimal only");
         document.forms[0].txtNoofHrs.focus();
         return false;
     }
    
     function MoreThanOnePoint(strString) {
         var strChar;
         var blnResult = true;
         var varcount = 0;
    
         for (i = 0; i < strString.length && blnResult == true; i++) {
    
             if (strString.charAt(i) == ".") {
                 varcount++;
                 if (varcount > 1) {
                     //alert("Please enter one decimal only");
                     blnResult = false;
                 }
             }
         }
         return blnResult;
     }
    
    0 讨论(0)
提交回复
热议问题