密码验证

创建于 2024-12-03 / 45
字体: [默认] [大] [更大]

了解如何使用 CSS 和 JavaScript 创建密码验证表单。


密码验证

亲自试一试 »


创建密码验证表单

步骤 1) 添加 HTML:

实例

<div class="container">
  <form action="/action_page.php">
    <label for="usrname">Username</label>
    <input type="text" id="usrname" name="usrname" required>

    <label for="psw">Password</label>
  <  input type="password" id="psw" name="psw" pattern="(?=.*d)(?=.*[a-z])(?=.*[A-Z]).{8,}" title="Must contain at least one number and one uppercase and lowercase letter, and at least 8 or more characters" required>

    <input type="submit" value="Submit">
  </form>
</div>

<div id="message">
  <h3>Password must contain the following:</h3>
  <p id="letter" class="invalid">A <b>lowercase</b> letter</p>
  <p id="capital" class="invalid">A <b>capital (uppercase)</b> letter</p>
  <p id="number" class="invalid">A <b>number</b></p>
  <p id="length" class="invalid">Minimum <b>8 characters</b></p>
</div>

注释: 我们在密码字段中使用模式属性(带有正则表达式)来设置提交表单的限制:它必须包含至少一个数字的 8 个或更多字符 , 以及一个大写和小写字母。



步骤 2) 添加 CSS:

设置输入字段和消息框的样式:

实例

/* 为所有输入字段设置样式 */
input {
  width: 100%;
  padding: 12px;
  border: 1px solid #ccc;
  border-radius: 4px;
  box-sizing: border-box;
  margin-top: 6px;
  margin-bottom: 16px;
}

/* 设置提交按钮的样式 */
input[type=submit] {
  background-color: #4CAF50;
  color: white;
}

/* 为输入设置容器样式 */
.container {
  background-color: #f1f1f1;
  padding: 20px;
}

/* 当用户点击密码字段时显示消息框 */
#message {
  display:none;
  background: #f1f1f1;
  color: #000;
  position: relative;
  padding: 20px;
  margin-top: 10px;
}

#message p {
  padding: 10px 35px;
  font-size: 18px;
}

/* 要求正确时添加绿色文本颜色和复选标记 */
.valid {
  color: green;
}

.valid:before {
  position: relative;
  left: -35px;
  content: "&#10004;";
}

/* 添加红色文本颜色和“x”; 要求错误时的图标 */
.invalid {
  color: red;
}

.invalid:before {
  position: relative;
  left: -35px;
  content: "&#10006;";
}
步骤 3) 添加 JavaScript:

实例

<script>
var myInput = document.getElementById("psw");
var letter = document.getElementById("letter");
var capital = document.getElementById("capital");
var number = document.getElementById("number");
var length = document.getElementById("length");

// 当用户点击密码字段时,显示消息框
myInput.onfocus = function() {
  document.getElementById("message").style.display = "block";
}

// 当用户在密码域外点击时,隐藏消息框
myInput.onblur = function() {
  document.getElementById("message").style.display = "none";
}

// 当用户开始在密码字段中输入内容时
myInput.onkeyup = function() {
  // Validate lowercase letters
  var lowerCaseLetters = /[a-z]/g;
  if(myInput.value.match(lowerCaseLetters)) {
    letter.classList.remove("invalid");
    letter.classList.add("valid");
  } else {
    letter.classList.remove("valid");
    letter.classList.add("invalid");
}

  // 验证大写字母
  var upperCaseLetters = /[A-Z]/g;
  if(myInput.value.match(upperCaseLetters)) {
    capital.classList.remove("invalid");
    capital.classList.add("valid");
  } else {
    capital.classList.remove("valid");
    capital.classList.add("invalid");
  }

  // 验证数字
  var numbers = /[0-9]/g;
  if(myInput.value.match(numbers)) {
    number.classList.remove("invalid");
    number.classList.add("valid");
  } else {
    number.classList.remove("valid");
    number.classList.add("invalid");
  }

  // 验证长度
  if(myInput.value.length >= 8) {
    length.classList.remove("invalid");
    length.classList.add("valid");
  } else {
    length.classList.remove("valid");
    length.classList.add("invalid");
  }
}
</script>
亲自试一试 »

提示:转到我们的HTML 表单教程,了解有关 HTML 表单的更多信息。



0 人点赞过