> 웹 프론트엔드 > 프런트엔드 Q&A > JavaScript를 사용하여 등록 정보를 확인하는 방법에 대해 토론

JavaScript를 사용하여 등록 정보를 확인하는 방법에 대해 토론

PHPz
풀어 주다: 2023-04-25 10:27:16
원래의
443명이 탐색했습니다.

인터넷이 발달하면서 등록은 많은 사람들이 반드시 완료해야 하는 작업이 되었습니다. 웹사이트와 애플리케이션에 등록하는 것이 매우 보편화되었으며, 이러한 등록 프로세스에서는 사용자가 사용자 이름, 비밀번호, 이메일 주소 등과 같은 많은 개인 정보를 입력해야 합니다. 이 정보의 신뢰성과 보안을 보장하기 위해 등록 정보를 확인해야 합니다. 웹 개발에서는 JavaScript 유효성 검사가 널리 사용됩니다. 이 기사에서는 JavaScript를 사용하여 등록 정보를 확인하고 몇 가지 특수 기능을 추가하는 방법에 대해 설명합니다.

일반적으로 프런트 엔드 양식 유효성 검사 프로세스는 포커스를 얻고 포커스를 잃을 때 시작됩니다. JavaScript를 사용하면 포커스를 얻었을 때 프롬프트 메시지를 팝업하고 포커스를 잃었을 때 해당 검증을 수행할 수 있습니다.

먼저 HTML 마크업에서 양식 요소가 포함된 양식을 만들어야 합니다. 양식 요소에는 입력 필드와 제출 버튼이 포함되어야 합니다. 이 예에서는 간단한 등록 양식을 예로 사용하겠습니다.

<form name="registerForm" onsubmit="return validateForm()" action="/submit-form" method="POST">
    <label>用户名:</label><input type="text" name="userName" required /><br />
    <label>密码:</label><input type="password" name="password" required /><br />
    <label>确认密码:</label><input type="password" name="rePassword" required /><br />
    <label>电子邮件:</label><input type="email" name="email" required /><br />
    <button type="submit">注册</button>
</form>
로그인 후 복사

양식 요소에서 "required" 및 "onsubmit"과 같은 몇 가지 새로운 속성을 볼 수 있습니다. 그 중 "필수"는 양식을 제출하기 전에 입력 상자를 채워야 함을 의미하고, "onsubmit"은 양식을 제출하기 전에 실행되는 JavaScript 함수를 의미합니다.

다음으로 양식 데이터의 유효성을 검사하는 JavaScript 함수를 구현해야 합니다. 이 예에서는 verifyForm()이라는 함수를 구현합니다. 이 함수는 양식에 입력된 데이터를 가져와서 일부 유효성 검사를 수행합니다.

function validateForm() {
  // Get the input data
  var username = document.forms["registerForm"]["userName"].value;
  var password = document.forms["registerForm"]["password"].value;
  var repassword = document.forms["registerForm"]["rePassword"].value;
  var email = document.forms["registerForm"]["email"].value;

  // Check username
  if (username == "") {
    alert("用户名不能为空!");
    document.forms["registerForm"]["userName"].focus();
    return false;
  }

  // Check password
  if (password == "") {
    alert("密码不能为空!");
    document.forms["registerForm"]["password"].focus();
    return false;
  }

  // Check confirm password
  if (repassword == "") {
    alert("确认密码不能为空!");
    document.forms["registerForm"]["rePassword"].focus();
    return false;
  } else {
    if (repassword != password) {
      alert("两次密码不匹配!");
      document.forms["registerForm"]["password"].value = "";
      document.forms["registerForm"]["rePassword"].value = "";
      document.forms["registerForm"]["password"].focus();
      return false;
    }
  }

  // Check email
  var emailReg = /^([\w-]+\.)*?[\w-]+@[\w-]+\.([\w-]+\.)*?[\w]+$/;
  if (email == "") {
    alert("电子邮件不能为空!");
    document.forms["registerForm"]["email"].focus();
    return false;
  } else if (!emailReg.test(email)) {
    alert("电子邮件格式不正确!");
    document.forms["registerForm"]["email"].value = "";
    document.forms["registerForm"]["email"].focus();
    return false;
  }

  // If all the data is correct, return true
  return true;
}
로그인 후 복사

이 함수에서는 몇 가지 간단한 유효성 검사 조건을 사용하여 양식 데이터의 정확성을 확인합니다. 예를 들어, 사용자 이름이 비어 있는지 확인하고, 비밀번호와 확인 비밀번호가 동일한지 확인하고, 이메일 형식이 올바른지 확인하세요. 입력 데이터가 요구 사항을 충족하지 않으면 경고 메시지가 나타나고 양식 제출을 방지하기 위해 false가 반환됩니다. 모든 데이터가 요구 사항을 충족하면 true를 반환합니다.

다음으로 포커스를 얻고 포커스를 잃는 입력 상자에 해당 작업을 수행하는 JS 함수를 추가해야 합니다.

// Add onfocus event
document.getElementsByName("userName")[0].onfocus = function() {
  document.getElementsByName("userName")[0].nextElementSibling.innerHTML = "请输入用户名";
};

document.getElementsByName("password")[0].onfocus = function() {
  document.getElementsByName("password")[0].nextElementSibling.innerHTML = "请输入密码";
};

document.getElementsByName("rePassword")[0].onfocus = function() {
  document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "请再次输入密码";
};

document.getElementsByName("email")[0].onfocus = function() {
  document.getElementsByName("email")[0].nextElementSibling.innerHTML = "请输入电子邮件地址";
};

// Add onblur event
document.getElementsByName("userName")[0].onblur = function() {
  if (document.getElementsByName("userName")[0].value == "") {
    document.getElementsByName("userName")[0].nextElementSibling.innerHTML = "用户名不能为空!";
  } else {
    document.getElementsByName("userName")[0].nextElementSibling.innerHTML = "";
  }
};

document.getElementsByName("password")[0].onblur = function() {
  if (document.getElementsByName("password")[0].value == "") {
    document.getElementsByName("password")[0].nextElementSibling.innerHTML = "密码不能为空!";
  } else {
    document.getElementsByName("password")[0].nextElementSibling.innerHTML = "";
  }
};

document.getElementsByName("rePassword")[0].onblur = function() {
  if (document.getElementsByName("rePassword")[0].value == "") {
    document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "确认密码不能为空!";
  } else if (document.getElementsByName("rePassword")[0].value != document.getElementsByName("password")[0].value) {
    document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "两次密码不匹配!";
  } else {
    document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "";
  }
};

document.getElementsByName("email")[0].onblur = function() {
  var email = document.getElementsByName("email")[0].value;
  var emailReg = /^([\w-]+\.)*?[\w-]+@[\w-]+\.([\w-]+\.)*?[\w]+$/;

  if (email == "") {
    document.getElementsByName("email")[0].nextElementSibling.innerHTML = "电子邮件不能为空!";
  } else if (!emailReg.test(email)) {
    document.getElementsByName("email")[0].nextElementSibling.innerHTML = "电子邮件格式不正确!";
  } else {
    document.getElementsByName("email")[0].nextElementSibling.innerHTML = "";
  }
};
로그인 후 복사

이 코드에서는 각 입력 필드에 대한 이벤트 핸들러를 추가했습니다. 초점을 맞추면 프롬프트 메시지가 표시되고, 초점을 잃은 후에는 확인 결과가 표시됩니다. 예를 들어, 사용자 이름을 입력하면 텍스트 상자 옆에 "사용자 이름을 입력하세요"라는 메시지가 표시되고, 입력이 올바르지 않은 경우 특정 오류 메시지가 표시됩니다.

마지막으로 다음 코드를 조합하여 완전한 예제를 구성할 수 있습니다.

<form name="registerForm" onsubmit="return validateForm()" action="/submit-form" method="POST">
    <label>用户名:</label><input type="text" name="userName" required /><span></span><br />
    <label>密码:</label><input type="password" name="password" required /><span></span><br />
    <label>确认密码:</label><input type="password" name="rePassword" required /><span></span><br />
    <label>电子邮件:</label><input type="email" name="email" required /><span></span><br />
    <button type="submit">注册</button>
</form>

<script>
  // Add onfocus event
  document.getElementsByName("userName")[0].onfocus = function() {
    document.getElementsByName("userName")[0].nextElementSibling.innerHTML = "请输入用户名";
  };

  document.getElementsByName("password")[0].onfocus = function() {
    document.getElementsByName("password")[0].nextElementSibling.innerHTML = "请输入密码";
  };

  document.getElementsByName("rePassword")[0].onfocus = function() {
    document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "请再次输入密码";
  };

  document.getElementsByName("email")[0].onfocus = function() {
    document.getElementsByName("email")[0].nextElementSibling.innerHTML = "请输入电子邮件地址";
  };

  // Add onblur event
  document.getElementsByName("userName")[0].onblur = function() {
    if (document.getElementsByName("userName")[0].value == "") {
      document.getElementsByName("userName")[0].nextElementSibling.innerHTML = "用户名不能为空!";
    } else {
      document.getElementsByName("userName")[0].nextElementSibling.innerHTML = "";
    }
  };

  document.getElementsByName("password")[0].onblur = function() {
    if (document.getElementsByName("password")[0].value == "") {
      document.getElementsByName("password")[0].nextElementSibling.innerHTML = "密码不能为空!";
    } else {
      document.getElementsByName("password")[0].nextElementSibling.innerHTML = "";
    }
  };

  document.getElementsByName("rePassword")[0].onblur = function() {
    if (document.getElementsByName("rePassword")[0].value == "") {
      document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "确认密码不能为空!";
    } else if (document.getElementsByName("rePassword")[0].value != document.getElementsByName("password")[0].value) {
      document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "两次密码不匹配!";
    } else {
      document.getElementsByName("rePassword")[0].nextElementSibling.innerHTML = "";
    }
  };

  document.getElementsByName("email")[0].onblur = function() {
    var email = document.getElementsByName("email")[0].value;
    var emailReg = /^([\w-]+\.)*?[\w-]+@[\w-]+\.([\w-]+\.)*?[\w]+$/;

    if (email == "") {
      document.getElementsByName("email")[0].nextElementSibling.innerHTML = "电子邮件不能为空!";
    } else if (!emailReg.test(email)) {
      document.getElementsByName("email")[0].nextElementSibling.innerHTML = "电子邮件格式不正确!";
    } else {
      document.getElementsByName("email")[0].nextElementSibling.innerHTML = "";
    }
  };

  function validateForm() {
    // Get the input data
    var username = document.forms["registerForm"]["userName"].value;
    var password = document.forms["registerForm"]["password"].value;
    var repassword = document.forms["registerForm"]["rePassword"].value;
    var email = document.forms["registerForm"]["email"].value;

    // Check username
    if (username == "") {
      alert("用户名不能为空!");
      document.forms["registerForm"]["userName"].focus();
      return false;
    }

    // Check password
    if (password == "") {
      alert("密码不能为空!");
      document.forms["registerForm"]["password"].focus();
      return false;
    }

    // Check confirm password
    if (repassword == "") {
      alert("确认密码不能为空!");
      document.forms["registerForm"]["rePassword"].focus();
      return false;
    } else {
      if (repassword != password) {
        alert("两次密码不匹配!");
        document.forms["registerForm"]["password"].value = "";
        document.forms["registerForm"]["rePassword"].value = "";
        document.forms["registerForm"]["password"].focus();
        return false;
      }
    }

    // Check email
    var emailReg = /^([\w-]+\.)*?[\w-]+@[\w-]+\.([\w-]+\.)*?[\w]+$/;
    if (email == "") {
      alert("电子邮件不能为空!");
      document.forms["registerForm"]["email"].focus();
      return false;
    } else if (!emailReg.test(email)) {
      alert("电子邮件格式不正确!");
      document.forms["registerForm"]["email"].value = "";
      document.forms["registerForm"]["email"].focus();
      return false;
    }

    // If all the data is correct, return true
    return true;
  }
</script>
로그인 후 복사

위는 JavaScript를 사용하여 등록 정보를 확인하는 과정입니다. 이 예를 통해 프런트엔드 검증이 사용자 경험과 데이터 보안을 크게 향상시킬 수 있음을 알 수 있습니다. 따라서 웹 개발에서는 프런트엔드 양식 검증과 백엔드 데이터 검증이 함께 진행되어 완전한 검증 시스템을 달성합니다.

위 내용은 JavaScript를 사용하여 등록 정보를 확인하는 방법에 대해 토론의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿