javascript - 社会安全号码输入验证

标签 javascript jquery html css

我有 this 样本:

function ssnFormat() {
  $("#ssn").on('blur change', function() {
    text = $(this).val().replace(/(\d{3})(\d{2})(\d{4})/, "$3-$2-$4");
    if ($(this).val() == '' || $(this).val().match(text) || $(this).val().length == 0) {
      $(this).removeClass('valid').addClass('invalid');
    } else {
      $(this).removeClass('invalid').addClass('valid');
    }
  });
}

$("#ssn").on('blur change', function() {
  ssnFormat();
});
.valid {
  border: 1px solid blue;
}

.invalid {
  border: 1px solid red;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<input class="required-input" id="ssn" maxlength="9" type="text" name="ssn" placeholder="123-45-6789">

我想做的这些事情是:

  1. 如果我编写以下文本,我想验证此格式 123-12-1234

  2. 如果我写 123456789 我想在点击这种格式的外部输入时进行转换

    123-12-1234

我尝试使用下面的函数来做到这一点,但不起作用

$("#ssn").on("click", function() {
        var thisVal = $(this).val();
        var value = thisVal.replace(/[^\/\d]/g,''); //here is a problem
        $(this).val(value);
    });

你能帮我解决这个问题吗?

提前致谢!

最佳答案

试试这个

function myFunc() {
   var patt = new RegExp("\d{3}[\-]\d{2}[\-]\d{4}");
   var x = document.getElementById("ssn");
   var res = patt.test(x.value);
   if(!res){
    x.value = x.value
        .match(/\d*/g).join('')
        .match(/(\d{0,3})(\d{0,2})(\d{0,4})/).slice(1).join('-')
        .replace(/-*$/g, '');
   }
}
.valid{
  border:1px solid blue;
}
.invalid{
  border:1px solid red;
}
<input class="required-input" id="ssn" type="text" name="ssn" placeholder="123-45-6789" onBlur = "myFunc()">

还有另一种方法可以强制用户始终输入该模式 -

<input class="required-input" id="ssn" type="text" name="ssn" placeholder="123-45-6789" onBlur = "myFunc()" required pattern="\d{3}[\-]\d{2}[\-]\d{4}">

关于javascript - 社会安全号码输入验证,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38074856/

相关文章:

Javascript 在 Safari 和 Chrome 中显示,但在 Firefox 中不显示?

javascript - 与巧克力 js 循环的全屏图像

html - 导航链接 <a> 中的 <i> 元素 - 无法关闭悬停突出显示

php - 用户 ID 在页面上不起作用

javascript - 使用哪个 javascript datepicker 插件/库以获得最大的灵活性

javascript - React Native ListView 数据源始终为 null

javascript - 检测 altKey 和/或 ctrlKey

javascript - Javascript 中未定义全局变量

javascript - jQuery 变量无缘无故变得未定义

PHP MySQL 注册页面不工作