Перевірка JavaScript для порожнього поля введення


95

У мене є це поле введення, яке <input name="question"/>я хочу викликати функцію IsEmpty під час надсилання, натиснувши кнопку "Відправити".

Я спробував код нижче, але не працював. будь-яка порада?

<html>

<head>
  <title></title>
  <meta http-equiv="Content-Type" content="text/html; charset=unicode" />
  <meta content="CoffeeCup HTML Editor (www.coffeecup.com)" name="generator" />
</head>

<body>


  <script language="Javascript">
    function IsEmpty() {

      if (document.form.question.value == "") {
        alert("empty");
      }
      return;
    }
  </script>
  Question: <input name="question" /> <br/>

  <input id="insert" onclick="IsEmpty();" type="submit" value="Add Question" />

</body>

</html>


Ви прийняли недійсну відповідь . Перевірка нуля є дивною, оскільки введення (або текстове поле) завжди повертає рядок. Також не слід використовувати вбудований JavaScript. Також не слід користуватися наосліп return false... тощо тощо
Роко К.

Відповіді:


122

<script type="text/javascript">
  function validateForm() {
    var a = document.forms["Form"]["answer_a"].value;
    var b = document.forms["Form"]["answer_b"].value;
    var c = document.forms["Form"]["answer_c"].value;
    var d = document.forms["Form"]["answer_d"].value;
    if (a == null || a == "", b == null || b == "", c == null || c == "", d == null || d == "") {
      alert("Please Fill All Required Field");
      return false;
    }
  }
</script>

<form method="post" name="Form" onsubmit="return validateForm()" action="">
  <textarea cols="30" rows="2" name="answer_a" id="a"></textarea>
  <textarea cols="30" rows="2" name="answer_b" id="b"></textarea>
  <textarea cols="30" rows="2" name="answer_c" id="c"></textarea>
  <textarea cols="30" rows="2" name="answer_d" id="d"></textarea>
</form>


2
'onsubmit = "return validate ()"' потрібно змінити. validate - це не ім'я функції. Це має бути 'onsubmit = "return validateForm ()"'
tazboy

3
Найкраще було б пояснити відповідь та сумнів ОП.
Vishal

7
Це прийнято насправді недійсним. Коми у ifвиписці спричинять повернення лише останнього чека: stackoverflow.com/a/5348007/713874
Bing

35

Дивіться робочий приклад тут


Вам не вистачає необхідного <form>елемента. Ось яким має бути ваш код:

function IsEmpty() {
  if (document.forms['frm'].question.value === "") {
    alert("empty");
    return false;
  }
  return true;
}
<form name="frm">
  Question: <input name="question" /> <br />
  <input id="insert" onclick="return IsEmpty();" type="submit" value="Add Question" />
</form>


Чи є спосіб зробити це для всіх полів у формах?
запасний цикл

34

Поле введення може мати пробіли , ми хочемо запобігти цьому.
Використовуйте String.prototype.trim () :

function isEmpty(str) {
    return !str.trim().length;
}

Приклад:

const isEmpty = str => !str.trim().length;

document.getElementById("name").addEventListener("input", function() {
  if( isEmpty(this.value) ) {
    console.log( "NAME is invalid (Empty)" )
  } else {
    console.log( `NAME value is: ${this.value}` );
  }
});
<input id="name" type="text">


1
Крім null та "", у моєму коді мені також не вистачало цієї частини. У мене це спрацювало. Спасибі Роко.
Педро Соуза,

17

Я хотів би додати необхідний атрибут на випадок, якщо користувач вимкнув javascript:

<input type="text" id="textbox" required/>

Він працює на всіх сучасних браузерах.



7

Додайте ідентифікатор "питання" до елемента введення, а потім спробуйте наступне:

   if( document.getElementById('question').value === '' ){
      alert('empty');
    }

Причина, по якій ваш поточний код не працює, полягає у тому, що у вас немає тегу FORM. Також пошук із використанням "name" не рекомендується, оскільки його застарілий.

Дивіться відповідь @Paul Dixon у цій публікації: Чи вважається атрибут 'name' застарілим для <a> прив'язних тегів?


1
if(document.getElementById("question").value == "")
{
    alert("empty")
}

1
... в <input>елементі немає атрибута "id" ; це працювало б лише в IE, оскільки IE зламаний.
Пойнті

вибачте, я думав, що є ідентифікатор, document.getElementsByName ("питання") [0] .value, або просто додати ідентифікатор до елемента
Kenneth J

1

Просто додайте тег ID до елемента введення ... тобто:

і перевірте значення елемента у вашому javascript:

document.getElementById ("питання"). значення

Ах, дістаньте firefox / firebug. Це єдиний спосіб зробити javascript.


0

Моє рішення нижче в es6, тому що я використав, constякщо ви віддаєте перевагу es5, ви можете замінити все constна var.

const str = "       Hello World!        ";
// const str = "                     ";

checkForWhiteSpaces(str);

function checkForWhiteSpaces(args) {
    const trimmedString = args.trim().length;
    console.log(checkStringLength(trimmedString))     
    return checkStringLength(trimmedString)        
}

// If the browser doesn't support the trim function
// you can make use of the regular expression below

checkForWhiteSpaces2(str);

function checkForWhiteSpaces2(args) {
    const trimmedString = args.replace(/^\s+|\s+$/gm, '').length;
    console.log(checkStringLength(trimmedString))     
    return checkStringLength(trimmedString)
}

function checkStringLength(args) {
    return args > 0 ? "not empty" : "empty string";
}


0

<pre>
       <form name="myform" action="saveNew" method="post" enctype="multipart/form-data">
           <input type="text"   id="name"   name="name" /> 
           <input type="submit"/>
       </form>
    </pre>

<script language="JavaScript" type="text/javascript">
  var frmvalidator = new Validator("myform");
  frmvalidator.EnableFocusOnError(false);
  frmvalidator.EnableMsgsTogether();
  frmvalidator.addValidation("name", "req", "Plese Enter Name");
</script>

перед використанням наведеного вище коду вам потрібно додати файл gen_validatorv31.js


0

Поєднуючи всі підходи, ми можемо зробити щось подібне:

const checkEmpty = document.querySelector('#checkIt');
checkEmpty.addEventListener('input', function () {
  if (checkEmpty.value && // if exist AND
    checkEmpty.value.length > 0 && // if value have one charecter at least
    checkEmpty.value.trim().length > 0 // if value is not just spaces
  ) 
  { console.log('value is:    '+checkEmpty.value);}
  else {console.log('No value'); 
  }
});
<input type="text" id="checkIt" required />

Зверніть увагу, що якщо ви справді хочете перевірити значення, ви повинні це робити на сервері, але це поза рамками цього питання.


0

Ви можете переглядати кожен ввід після подання та перевіряти, чи він не пустий

let form = document.getElementById('yourform');

form.addEventListener("submit", function(e){ // event into anonymous function
  let ver = true;
  e.preventDefault(); //Prevent submit event from refreshing the page

  e.target.forEach(input => { // input is just a variable name, e.target is the form element
     if(input.length < 1){ // here you're looping through each input of the form and checking its length
         ver = false;
     }
  });

  if(!ver){
      return false;
  }else{
     //continue what you were doing :)
  } 
})

0

<script type="text/javascript">
  function validateForm() {
    var a = document.forms["Form"]["answer_a"].value;
    var b = document.forms["Form"]["answer_b"].value;
    var c = document.forms["Form"]["answer_c"].value;
    var d = document.forms["Form"]["answer_d"].value;
    if (a == null || a == "", b == null || b == "", c == null || c == "", d == null || d == "") {
      alert("Please Fill All Required Field");
      return false;
    }
  }
</script>

<form method="post" name="Form" onsubmit="return validateForm()" action="">
  <textarea cols="30" rows="2" name="answer_a" id="a"></textarea>
  <textarea cols="30" rows="2" name="answer_b" id="b"></textarea>
  <textarea cols="30" rows="2" name="answer_c" id="c"></textarea>
  <textarea cols="30" rows="2" name="answer_d" id="d"></textarea>
</form>


Привіт, коли ви надаєте рішення, було б чудово вказати причину, чому ваше рішення вирішує проблему, яка може допомогти майбутнім читачам.
Ехсан Махмуд
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.