【问题标题】:HTML5 validationHTML5 验证
【发布时间】:2012-03-15 19:21:39
【问题描述】:

我想知道 HTML5 是否有双重输入的表单验证(写 2 个相同的密码),你能写自己的例外吗?

提前谢谢!

【问题讨论】:

  • 虽然您可以这样做,但您确实应该避免这样做。通过 Ajax 在服务器端进行验证。

标签: forms html validation


【解决方案1】:

我很确定这是不可能的。此外,它可以很容易地被 javascript 覆盖,所以为什么不使用它呢?

这很好用:

<script language="javascript"> 
function checkPassword() { 
    if (document.pwForm.pw1.value != document.pwForm.pw2.value) { 
        alert ('The passwords do not match!');
        return false; 
    } 
} 
</script>
<form action="filename.ext" name="pwForm" method="GET/POST">
    <input type="password" name="pw1" value=""><br />
    <input type="password" name="pw2" value=""><br />
    <input type="Submit" name="CheckPassword" value="Check Passwords" onClick="return checkPassword();">
</form>

【讨论】:

  • 虽然答案是对的。这段代码有很多问题: 1. 如果 field1 没有改变,自定义错误不会被添加。 2. 如果有人在 pw1 而不是 pw2 中输入了错误的密码,并且在该字段保持无效后更改了密码,尽管它是有效的)。 3.只有在字段还没有自定义错误或者自定义错误是由同一个脚本添加的情况下才应该更改自定义有效性(您需要为此测试validity.customError/validationMessage)
【解决方案2】:

如果你想要一些更好的和 HTML5 使用的东西,试试这个: http://www.html5rocks.com/en/tutorials/forms/html5forms/

<label>Password:</label>
<input type="password" id="password" name="password">
<label>Confirm Password:</label>
<input type="password" id="passwordconf" name="passwordconf" oninput="check(this)">
<script language='javascript' type='text/javascript'>
function check(input) {
    if (input.value != document.getElementById('password').value) {
        input.setCustomValidity('The two passwords must match.');
    } else {
        // input is valid -- reset the error message
        input.setCustomValidity('');
   }
}
</script>

通过将其添加到您的 CSS(如下)中,让它看起来很漂亮。当 HTML5 验证失败时,它会在有问题的输入字段周围放置一个红色边框。

:invalid {
     border: 2px solid #ff0000;
}

全部完成。您仍应使用 alert() 或服务器端验证来确保用户正确输入了两个密码。不要依赖客户端的任何东西。

【讨论】:

    【解决方案3】:

    我遇到了类似的问题,为了使用 HTML5 api 解决它,我这样做了:设置密码模式以包含至少八个字母和一个数字。然后为了让它们匹配我做了:

        var password = document.querySelector('#password'),
            passwordConfirm = document.querySelector('#password_confirm');
    
        [].forEach.call([password, passwordConfirm], function(el) {
            el.addEventListener('input', function() {
                if (!el.validity.patternMismatch) {
                    if ( password.value === passwordConfirm.value ) {
                        try{password.setCustomValidity('')}catch(e){}
                    } else {
                        password.setCustomValidity("Password and password confirm doesn\'t match")
                    }
                }
            }, false)
        });
    

    el.validity.patternMismatch 先检查模式有效性,然后检查两者的有效性。 这是我使用模式输入的密码。

    &lt;input type="password" pattern="^((?=.*(\d|\W))(?=.*[a-zA-Z]).{8,})$" id="password" /&gt;

    【讨论】:

      【解决方案4】:

      感谢 Kicker,这真的很有用。

      我对它进行了一点扩展,以使密码和密码确认输入在输入开始时立即无效。

      var password = document.querySelector(' input[name=usr_password]');
      var passwordConfirm = document.querySelector(' input[name=usr_password_confirm]');
      if (password && passwordConfirm)
      {
          [].forEach.call([password, passwordConfirm], function(el) {
              el.addEventListener('input', function() {
                  if ( el.validity.patternMismatch === false) {
                      if ( password.value === passwordConfirm.value ) {
                          try{
                              password.setCustomValidity('');
                              passwordConfirm.setCustomValidity('');
      
                          }
                          catch(e){}
                      }
                      else {
                          password.setCustomValidity("The two passwords do not match");
                      }
                  }
                  if ((password.checkValidity() && passwordConfirm.checkValidity()) === false)
                  {
                      password.setCustomValidity("The two passwords do not match, and they don't comply with the password rules.");
                      passwordConfirm.setCustomValidity("The two passwords do not match, and they don't comply with the password rules.");
                  }
                  else
                  {
                      password.setCustomValidity('');
                      passwordConfirm.setCustomValidity('');
      
                  }
              }, false)
          });
      }
      

      【讨论】:

        【解决方案5】:

        我想这就是你要找的。​​p>

        <p>Password: <input type="password" required pattern="(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{6,}" name="pwd1" onchange="
          this.setCustomValidity(this.validity.patternMismatch ? 'Password must contain at least 6 characters, including UPPER/lowercase and numbers' : '');
          if(this.checkValidity()) form.pwd2.pattern = this.value;
        "></p>
        <p>Confirm Password: <input type="password" required pattern="(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{6,}" name="pwd2" onchange="
          this.setCustomValidity(this.validity.patternMismatch ? 'Please enter the same Password as above' : '');
        "></p>
        

        这将执行密码和重新输入密码字段验证。

        【讨论】:

          【解决方案6】:

          另一个选择是使用http://jqueryvalidation.org/validate/,如果你不介意使用 Jquery 来做你的脏活。

          查看http://jqueryvalidation.org/equalTo-method

          <form id="myform">
            <label for="password">Password</label>
            <input id="password" name="password" />
            <br/>
            <label for="password_again">Again</label>
            <input class="left" id="password_again" name="password_again" />
            <br>
            <input type="submit" value="Validate!">
          </form>
          
          <script>
            $( "#myform" ).validate({
              rules: {
                password: "required",
                password_again: {
                  equalTo: "#password"
                }
              }
            });
          </script>
          

          如果需要,您还可以编写更复杂的方法:http://jqueryvalidation.org/category/plugin/

          【讨论】:

            猜你喜欢
            • 2014-06-12
            • 1970-01-01
            • 2023-03-19
            • 2012-07-20
            • 2013-03-05
            • 2011-04-19
            • 1970-01-01
            • 1970-01-01
            相关资源
            最近更新 更多