Как сделать - Проверку пароля
Узнать, как создать форму проверки пароля с помощью CSS и JavaScript.
Проверка пароля
Создание формы проверки пароля
Шаг 1) Добавить HTML:
Пример
<div class="container">
<form action="/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 (с регулярным выражением) внутри поля password, чтобы установить ограничение для отправки формы: она должна содержать 8 или более символов, которые имеют по крайней мере одно число, а также одну прописную и строчную букву.
Шаг 2) Добавить CSS:
Style the input fields and the message box:
Пример
/* Стиль всех полей ввода */
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: "✔";
}
/* Добавить красный цвет текста и собой "x" и значок, когда требования не правы */
.invalid {
color: red;
}
.invalid:before {
position: relative;
left: -35px;
content: "✖";
}
Шаг 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() {
// Проверка строчных букв
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.