Формы — Проверка номера телефона

Я пытаюсь создать функцию, которая позволит использовать номер телефона длиной от 9 до 11 цифр (в настоящее время функция позволяет использовать 11 цифр).

Когда я пишу функцию для проверки номера телефона и помещаю ее в конец своего JavaScript, моя функция проверки электронной почты больше не работает должным образом.
Мне нужно найти решение, которое позволит работать как с электронной почтой, так и с телефонным номером.

Если у кого-то есть решение, ваш вклад будет отличным.

введите здесь описание изображения

JSFiddle

HTML:

<form class="container" action="https://webto.salesforce.com/servlet/servlet.WebToLead?encoding=UTF-8" method="POST">
  <label>First Name
    <input id="first_name" maxlength="40" name="first_name" size="20" type="text" onkeyup="test()" required><i class="fa fa-check-circle" aria-hidden="true"></i>
  </label>
  <label>Last Name
    <input id="last_name" maxlength="80" name="last_name" size="20" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
  </label>
  <label>Email
    <input id="email" maxlength="80" name="email" size="20" type="text" onkeyup="test()"><i class="fa fa-times-circle-o" aria-hidden="true"></i>
  </label>
  <label>Phone
    <input id="phone" maxlength="40" name="phone" size="20" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
  </label>
  <label>City
    <input id="city" name="city" maxlength="40" size="20" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
  </label>
  <label>State/Province
    <input id="state" maxlength="20" name="state" size="20" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
  </label>
  <label id="co">Company
    <input id="company" name="company" type="text" onkeyup="test()"><i class="fa fa-check-circle" aria-hidden="true"></i>
  </label>
  <label>Comments
    <textarea id="comments"name="" id="" cols="30" rows="10" onkeyup="test()"></textarea>
    <input id="sub" type="submit" disabled="disabled" />
  </label>

  <div>                
      <select  hidden="true" id="00N6A000008yXMN" name="00N6A000008yXMN" title="Product Interest">
      <option value="">--None--</option>
      <option selected="selected" value="Visiant">Visiant</option>
      <option  value="Tessellate">Tessellate</option>
  </select><br>

  <select  hidden="true" id="lead_source" name="lead_source">
      <option value="">--None--</option>
      <option value="Internal">Internal</option>
  <option value="Trade Show">Trade Show</option>
  <option selected="selected" value="Website">Website</option>
  <option value="Direct Marketing">Direct Marketing</option>
  <option value="Social Media">Social Media</option>
  <option value="Other">Other</option>
  </select><br>
  </div>
</form>


CSS:

body {
  color: #fff;
  background-color: #f78e2a;
  text-align: center;
} 

form {
  color: #fff;
  background-color: #f78e2a;
  text-align: center;
  font-family: Lato;
}

* {
  box-sizing: border-box;
}

.form-title {
    font-size: 38px;
    color: #fff;
    font-family: "Lato";
    letter-spacing: 70px;
}

input[type="text"] {
  width: 100%;
  padding: 10px;
  background-color: #f9a558;
  border: 1px solid #fff;
}

input[type="text"]:focus {
  background-color: #fff;
}

input[type="text"]:visited {
  background-color: #fff;
}

.container {
  display: flex;
  flex-direction: column;
  padding: 5px 0;
  margin-left: 10%;
  margin-right: 10%;
}

textarea {
  width: 100%;
  background-color: #f9a558;
  border: 1px solid #fff;
}

textarea:focus {
  background-color: #fff;
}

#co {
  flex-basis: 100%;
  max-width: 100%;
}

label:nth-last-child(-n+2) {
  flex-basis: 100%;
  max-width: 100%;
}

select,
label {
  height: 50px;
  width: 48%;
  margin: 2% 1%;
  text-align: left;
  font-family: "Lato";
}

#sub {
  border-radius: 6px;
  width: 120px;
  height: 35px;
  text-transform: uppercase;
  display: block;
  margin-top: 10px;

}

button {
  margin-top: 10px;
  background-color: #B9B9B9;
  color: #959595;
  border-radius: 6px;
  width: 120px;
  height: 35px;
  margin-left: 1%;
  display: block;
}


button:focus {
  background-color: #fff;
  color: #f78e2a;
}

@media (max-width: 426px) {
  label {
    width: 98%;
  }
}

@media (min-width: 426px) {
  .container {
    flex-direction: row;
    flex-wrap: wrap;
    align-self: flex-start;
  }
}

label {
  position: relative;
}

.fa {
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translate(-50%, -5%);
  opacity: 0;
  transition: opacity .5s, color .5s;
}


[data-valid] + .fa {
  opacity: 1;
  color: green;
}

[data-valid="valid"] + .fa {
  color: green;
}

[data-valid="error"] + .fa {
  color: red;
}


jQuery:

function validateEmail(email) {
  var re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
  return re.test(email);
}

$('input[type="text"]').on('keyup', function() {
  var $label = $(this).closest('label');
  if ($(this).val().trim() != '') {
    if ($(this).is('#email')) {
      if (validateEmail($(this).val())) {
        $label.attr('data-valid', 'valid');
      } else {
        $label.attr('data-valid', 'error');
        console.log("this works")
      }
    } else {
      $label.attr('data-valid', 'valid');
      console.log("this works")
    }
  } else {
    $label.removeAttr('data-valid');
    console.log("this works")
  }
});


test = function() {
  if ($("#first_name").val() && $("#last_name").val() && $("#email").val() && $("#phone").val() && $("#city").val() && $("#state").val() && $("#company").val()) {
    $("#sub").removeAttr("disabled");
  }
}

function phoneNumber(phone)  {  
  var phoneno = /^\d{11}$/;  
  return phoneno.test(phone);
}

$('input[type="text"]').on('keyup', function() {
  if ($(this).val().trim() != '') {
    if ($(this).is('#phone')) {
      if (phoneNumber($(this).val())) {
        $(this).attr('data-valid','valid');
      } else {
        $(this).attr('data-valid','error');
        console.log("this works")
      }
    } else {
      $(this).attr('data-valid','valid');
        console.log("this works")
    }
  } else {
    $(this).removeAttr('data-valid');
    console.log("this works")
  }
});

person Missy Bur    schedule 12.07.2017    source источник


Ответы (2)


Я начал с вашего другого вопроса ... О проверке длины вашего телефона.

var phoneno = /^\d{9}|\d{10}|\d{11}$/;

Вышеприведенное вернет true, если найдет последовательность из 9, 10 или 11 цифр...
Но также и для 12, 13, до n цифр.

Вот как вы должны ограничить от 9 до 11 цифр, используя регулярное выражение:

var phoneno = /^\d{9,11}$/;

Короткое примечание о <input type="tel">, пока он не совместим с браузером, как показано здесь.

person Louys Patrice Bessette    schedule 13.07.2017
comment
Спасибо вам за это! Теперь я пытаюсь сделать так, чтобы форма исчезла при отправке и чтобы появилось окно благодарности. Я скоро опубликую это в новом вопросе. Вот моя скрипка для этого: jsfiddle.net/vvffpjxb/7 - person Missy Bur; 13.07.2017
comment
Вам нужно будет использовать ajax для этого. - person Louys Patrice Bessette; 13.07.2017

Вы дважды привязываетесь ко всем входам с типом текста. Просто привяжите один раз и проверьте оба ввода в этом обратном вызове:

(И ради любви к Питу перестаньте каждый раз воссоздавать свой $(this) объект)

$('input[type="text"]').on('keyup', function() {
  var $this = $(this); 
  var $label = $this.closest('label');
  if ($this.val().trim() != '') {
    if ($this.is('#email')) {
      if (validateEmail($this.val())) {
        $label.attr('data-valid', 'valid');
      } else {
        $label.attr('data-valid', 'error');
        console.log("this works")
      }
    } else if ($this.is('#phone')) {
      if (phoneNumber($this.val())) {
        $this.attr('data-valid','valid');
      } else {
        $this.attr('data-valid','error');
        console.log("this works")
      }
    } else {
      $label.attr('data-valid', 'valid');
      console.log("this works")
    }
  } else {
    $label.removeAttr('data-valid');
    console.log("this works")
  }
});
person Randy Hall    schedule 12.07.2017
comment
Это решение не сработало для меня, так как значки fa fa больше не отображались. Однако я решил проблему, изменив тип ввода для телефона на «тел». Вот скрипт для этого: 127.0 .0.1:8080/#контакт - person Missy Bur; 13.07.2017