验证电子邮件,添加事件侦听器键入功能

问题描述

我已经完成了此功能,使我可以验证电子邮件输入。它会显示一条错误消息,直到正确编写电子邮件为止。正确时,将删除消息。但是,如果我删除输入的电子邮件,则错误消息仍然存在。我尝试了if(input.value ===“”),但是什么也没有。如果有人可以帮助我,我将不胜感激。预先感谢。

Float
    const email = document.querySelector('#email');

    eventListeners();

    function eventListeners() {
      email.addEventListener('keyup',validateEmail);
    }

    function validateEmail() {

      const email = document.querySelector('.email'),inputEmail = document.querySelector('#email'),formatEmail = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
      if (inputEmail.value.match(formatEmail)) {
        email.removeChild(document.querySelector('.error'));
        alert("Valid email address!");
      } else {
        if (!document.querySelector('.error')) {

          if (inputEmail === "") {
            email.removeChild(document.querySelector('.error'));
          } else {
            const errorMessage = document.createElement('div');
            errorMessage.setAttribute('class','error');
            errorMessage.innerHTML = `<p>error</p>`;
            email.insertBefore(errorMessage,email.childNodes[4]);
          }
        }
      }
    }


我编辑了问题,现在可以了。

    <div class="campo email">
      <label for="email">Email:</label>
      <input type="email" id="email" name="email" placeholder="Email">
    </div>
const email = document.querySelector('#email');

eventListeners();

function eventListeners() {
  email.addEventListener('keyup',validateEmail);
}

function validateEmail() {

  const email = document.querySelector('.email'),}))$/;
  if (inputEmail.value.match(formatEmail)) {
    email.removeChild(document.querySelector('.error'));
    alert("Valid email address!");
  } else {
    if (!document.querySelector('.error')) {
      const errorMessage = document.createElement('div');
      errorMessage.setAttribute('class','error');
      errorMessage.innerHTML = `<p>error</p>`;
      email.insertBefore(errorMessage,email.childNodes[4]);
    } else if (inputEmail.value === "") {
      email.removeChild(document.querySelector('.error'));
    }
  }
}

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...