JS验证登录表单 - 我哪里出错了?

时间:2013-07-18 15:08:03

标签: javascript forms validation login

我有坚果要破解,现在已经裂开了一段时间。

我是编程初学者,那是为了介绍。我尝试实现JS表单验证,检查输入字段emailpassword,如果它符合某些条件,请在登录按钮上取消设置"disabled"属性。

我尝试了我的JS代码的组件,它运行得很好,但是当我将它合并到函数validate()时,它只是不起作用,我找不到原因。

这是我的HTML:

<!DOCTYPE html>
<head>
  <meta charset='UTF-8' />
  <title>$title</title>
  <link href='css/style.css' rel='stylesheet' type='text/css' />
  <script type='text/javascript' charset='utf-8' src='js/validateInput.js'></script>
</head>
<body>
  <div id='header'><h1>$title<h1></div>
  <form name='login' method='post' action=''>
    <table border='0'>
      <tr>
        <th>E-mail:</th>
        <td colspan='2'><input type='text' name='email' id='email' size='30' value='$posted_email'
     onkeyup='validate()' onclick='validate()' onchange='validate()' />
        </td>
      </tr>
      <tr>
        <th>Heslo:</th>
        <td><input type='password' name='pword' id='pword' size='21'
          onkeyup='validate()' onclick='validate()' onchange='validate()'/></td>
        <td><input type='submit' name='login' class='submit' id='loginBtn' value='OK' /></td>
      </tr>    
    </table>
  </form>
</body>

现在我的JS:

function $(id) {
  if (id.indexOf('#') == 0 || id.indexOf('.') == 0) {
    var name = id.substr(1);
    return id.indexOf('#') == 0 ? document.getElementById(name) : document.getElementsByClassName(name);
  }
  return (typeof document.getElementById('id') !== 'undefined') ? document.getElementById(id) : document.getElementsByClassName(id);
}
function validateEmail(string) {
  var re = /[\w\s\.\$\*\+\/\?\^\{\|\}\(\)]{1,64}@[\w]{1,250}\.[\w]{2,3}/;
  return re.test(string);
}

function validate() {
  var login = $('#loginBtn');
  var email = $('#email');
  var pword = $('#pword');
  if (!validateEmail(email.value)) {
    email.style.color = 'orange';
  } else if (pword.length > 0) {
    login.disabled = false;
  }
  return false;
}
window.onload = function() {$('#loginBtn').disabled = true;};

有什么想法吗?

1 个答案:

答案 0 :(得分:0)

问题出在这种情况:

  if (!validateEmail(email.value)) {
    email.style.color = 'orange';
  } else if (pword.length > 0) {
    login.disabled = false;
  }

将您的函数validate()更改为以下内容:

function validate() {
    var login = $('#loginBtn');
    var email = $('#email');
    var pword = $('#pword');
    var result = false;

    if (!validateEmail(email.value)) {
        email.style.color = 'orange';
    } else {
        email.style.color = 'black';
        result = true;
    }
    if (result && pword.value.length > 0) {
        login.disabled = false;
    } else {
        login.disabled = true;
    }
}

Fiddle demo.

希望这有帮助。