<MyRusakov.ru />

Написание лайфхаков на Python

Написание лайфхаков на Python

Данный курс научит Вас автоматизировать самые разные задачи на языке Python, благодаря чему Вы сэкономите на рутине тысячи и тысячи часов своей жизни. Курс состоит из 20 примеров в различных областях: файлы и директории, медиа-файлы, Интернет, Web-мастеринг, Unreal Engine. Каждый пример упрощает ту или иную задачу в своей области, при этом каждый из них создаётся прямо на Ваших глазах и тщательно комментируется.

Помимо самих уроков Вы так же получаете и множество упражнений. По сути, Вы создадите свои собственные 20 небольших проектов, благодаря чему у Вас появится и практика, и портфолио.

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Зачем Вы изучаете программирование/создание сайтов?

Валидация email в форме с помощью JS

Валидация email в форме с помощью JS

Одна из самых ценных информаций, которую пользователь передает на сайт - это email. Поэтому крайне важно проконтролировать правильность ввода email в поле формы. Такая процедура называется валидацией формы, которая происходит на стороне клиента, до отправки данных на сервер.

Создание формы

Создадим в учебной мини-форме одно поле (input) и индикатор реагирования на верно или неверно. Если email введен не в правильном формате, то индикатор станет красным. При успешном прохождении валидации - зеленым.

<form id="form" action="#">
    <div class="inputBox">
        <input type="text" id="email" placeholder="Enter Email Address">
        <span class="indicator"></span>
    </div>
</form>


Валидация email в форме с помощью JS.

Стилизация формы

В CSS стилях нельзя забывать про то, как будет выглядеть вводимый пользователем email.

@import url('https://fonts.googleapis.com/css?family=Poppins:300,300i,400,500,500,600,700,800,900&display=swap');
*{
    margin: 0;
    padding: 0;
    font-family: 'Poppins', sans-serif;
}
body{
    display: flex;
    justify-content: center;
    align-items: center;
    min-height: 100vh;
    background: #1b1b1d;
}
#form{
    position: relative;
    border: 2px solid #131313;
    background: #242424;
    background: linear-gradient(#1e2024,#18181c);
    border-radius: 4px;
    overflow: hidden;
}
#form #email{
    width: 300px;
    outline: none;
    border: none;
    padding: 12px 15px;
    background: transparent;
    padding-right: 50px;
    color: #fff;
    font-size: 18px;
}
#form #email:focus{
nbsp;   background: linear-gradient(#1e2024,#18181c);
}
#form .inputBox{
    position: relative;
}


Валидация email в форме с помощью JS.

Стилизация индикатора

В неактивном виде, индикатор почти незаметен на форме.

#form .inputBox .indicator{
    position: absolute;
    right: 20px;
    top: 20px;
    width: 10px;
    height: 10px;
    background: #555;
    border-radius: 50%;
}

Зададим в стилях красный цвет для невалидного индикатора и зеленый цвет для валидного.

#form.invalid .inputBox .indicator{
    background: #f00;
    box-shadow: 0 0 5px #f00,
        0 0 10px #f00,
        0 0 20px #f00,
        0 0 40px #f00;
}
#form.valid .inputBox .indicator{
    background: #0f0;
    box-shadow: 0 0 5px #0f0,
        0 0 10px #0f0,
        0 0 20px #0f0,
        0 0 40px #0f0;
}


Валидация email в форме с помощью JS.

JavaScript валидация формы

Повесим на input событие onkeyup, которое сработает при отпускании клавиши. Как только пользователь ввел email и отпустил клавишу, запустится функция validate().

<input type="text" id="email" onkeyup="validate()" placeholder="Enter Email Address">

Написание функции validate()

Найдем в документе элемент form и занесем его в переменную form. Затем по ID получим значение поля email и так же присвоим переменной email. Объявим переменную pattern и присвоим ей регулярное выражение. Регулярное выражение - это шаблон, задающий правила, которому должны соответствовать вводимые данные.

function validate(){
    var form = document.getElementById("form");
    var email = document.getElementById("email").value;
    var pattern = /^[^ ][email protected][^ ]+\.[a-z]{2,3}$/
    ...
}

С помощью метода match() сопоставим полученный email с регулярным выражением, применив условную конструкцию if-else. Если (if) email прошел проверку по шаблону, то добавится класс valid (зеленый индикатор), а invalid (красный индикатор) удалится из формы. В противном случае (else), все произойдет с точностью наоборот. Если поле оставить пустым (email == ""), то удалятся оба класса и индикатор снова будет серым.

function validate(){
    ...
    if(email.match(pattern))
    {
        form.classList.add("valid");
        form.classList.remove("invalid");
    }
    else{
        form.classList.remove("valid");
        form.classList.add("invalid");
    }
    if (email == "") {
        form.classList.remove("valid");
        form.classList.remove("invalid");
    }
}


Валидация email в форме с помощью JS.

Переходите на видеокурс по JavaScript и приобретайте необходимые навыки для получения востребованной профессии frontend-разработчика.

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.