Форма с проверкой пароля

 alexei 27/09/2021 - 09:07

Здесь вы узнаете, как форму с проверкой пароля при помощи CSS и JavaScript.



Как сделать форму с проверкой пароля

Шаг 1) Добавляем HTML:


<div class="container">
  <form action="//msiter.ru/action_page.php">
    <label for="usrname">Логин</label>
    <input type="text" id="usrname" name="usrname" required>

    <label for="psw">Пароль</label>
    <input type="password" id="psw" name="psw" pattern="(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,}" title="Должен содержать по меньшей мере одну цифру, одну большую и одну маленькую буквы латинского алфавита и быть в длину не менее 8 символов" required>
    
    <input type="submit" value="ОК">
  </form>
</div>

<div id="message">
  <h3>Пароль должен содержать:</h3>
  <p id="letter" class="invalid"><b>Маленькую</b> букву</p>
  <p id="capital" class="invalid"><b>Заглавную (большую)</b> букву</p>
  <p id="number" class="invalid"><b>Цифру</b></p>
  <p id="length" class="invalid">Минимум <b>8 символов</b></p>
</div>

Внимание! Мы используем атрибут pattern (с регулярным выражением) в поле ввода пароля, чтобы задать ограничение на ввод: это должно быть 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: #04AA6D;
  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: "✔";
}

/* Добавляем красный цвет и крест, когда требование не выполнено */
.invalid {
  color: red;
}

.invalid:before {
  position: relative;
  left: -35px;
  content: "✖";
}

Шаг 3) Добавляем JavaScript:


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() {
  // Проверяем на маленькие буквы
  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");
  }
}