-
Notifications
You must be signed in to change notification settings - Fork 0
/
script2.js
38 lines (31 loc) · 1.1 KB
/
script2.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
const inputs = document.querySelectorAll('.input');
const button = document.querySelector('button');
const popup = document.querySelector('.popup-wrapper')
const closeButton = document.querySelector('.popup-close')
button.addEventListener('click', () => {
popup.style.display = 'block'
})
closeButton.addEventListener('click', () => {
popup.style.display = 'none'
})
const handleFocus = ({ target }) => {
const span = target.previousElementSibling;
span.classList.add('span-active');
}
const handleFocusOut = ({ target }) => {
if (target.value === '') {
const span = target.previousElementSibling;
span.classList.remove('span-active');
}
}
const handleChange = () => {
const [username, password, email] = inputs;
if (username.value && password.value.length >= 8) {
button.removeAttribute('disabled');
} else {
button.setAttribute('disabled', '');
}
}
inputs.forEach((input) => input.addEventListener('focus', handleFocus));
inputs.forEach((input) => input.addEventListener('focusout', handleFocusOut));
inputs.forEach((input) => input.addEventListener('input', handleChange));