繁体   English   中英

文本框一个只带有数字,另一个带有逗号

[英]textbox one with number only and another with comma in jquery

我在表单中有两个文本框。 一个仅验证数字,另一个验证数字和逗号。

仅第一种情况。

function(textBoxObject) {
    var that = $(this),
    val = that.val();

    if (val === "" || isNaN(val)) {
      that.addClass("error");
    } else {
     that.removeClass("error");
    }
}

第二个案例编号和逗号。

如何处理另一个带有数字和逗号的文本框? 并且可以在第一个函数本身中添加逻辑吗?

我假设您将12,34视为非法,将1,234视为合法。 这是演示

function checkNumberWithComma(textBox) {
    if ((textBox.value == 0 || textBox.value) && textBox.value.match(/^\d{0,3}(?:,\d{3})*$/)) {
        $(textBox).removeClass("error");
    }
    else {
        $(textBox).addClass("error");
    }
}

和正则表达式:

^       means start
\d{0,3} means 0-3 digits
(?:     means non-capturing group 
,
\d{3}   means 3 digits
)
*       means repeat for 0 or more times
$       means end

您可以使用.indexOf()方法。

就像是...

if(val.indexOf(',') === -1) {
    ...your code here...
}

您可以尝试使用if(val.match(/^(\\d,?)*$/g))

它将允许一个空字符串,数字和以逗号分隔的数字。 但是,它的确允许在字符串的末尾使用逗号。

所以, 1,2,3,412341234,全部通过,但是,12,34foo将失败。

看看这个codepen ,我不完全知道您想要的行为,但是您可以尝试类似的方法。

JS

$(function(){
  function validateInput() {
      var that = $(this),
      val = that.val();
      if (that.attr('data-type') === 'number') {
        if (val === '' || isNaN(val)) that.addClass('error');
        else that.removeClass('error');
      }
      else {
        if (val.indexOf(',') === -1) that.addClass('error');
        else that.removeClass('error');
      }
  }

  $('input').change(validateInput);
});

HTML

<div>
  <label> Number
    <input type="text" data-type="number"/>
  </label>
</div>

<div>
  <label> Comma
    <input type="text"/>
  </label>
</div>

暂无
暂无

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

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