Кнопка Reset / Submit не будет работать после того, как текстовая область отредактирована пользователем? - PullRequest
0 голосов
/ 30 июня 2018

Кнопки сброса и отправки моей формы не работают, когда я редактирую вывод формы в текстовой области. Я создал форму, которая выводит пользовательские предложения на основе пользовательских данных. Если я не редактирую текстовую область, эти кнопки работают нормально, сбрасывая или повторно отправляя по клику. Однако, если я отредактирую текстовую область, все функциональные возможности закроются. Есть идеи? Спасибо! <3 </p>

<!DOCTYPE html>
<html>
<head>
  <title>Experiment</title>

  <style type="text/css">
    table,td,th{
      margin-left: auto;margin-right: auto
    }
    .display{
      display: flex;align-items: center;justify-content: center;
    }
    p{
      text-align: center;
    }
    textarea{
      display: block;margin-left:auto;margin-right: auto;
    }
  </style>

  <script type="text/javascript">

  function sentence(){
    document.getElementById("s1").style.display= 'block';
    document.getElementById("r1").style.display= 'block';
  {
  if(document.getElementById("z1").value==""){
    alert("Hi! Your dog's name is required for submission.")
    document.getElementById("z1").focus();
  }else if(document.getElementById("z2").value==""){
    alert("Hi! Your dog's gender is required for submission.")
  }else if(document.getElementById("z3").value==""){
    alert("Hi! Your dog's size is required for submission.")
  }else{
    const input1 = document.getElementById("z1").value
    const input2 = document.getElementById("z2").value
    const input3 = document.getElementById("z3").value
    document.getElementById("s1").innerHTML="My dog's name is " + input1 + ". " + input2 + " loves to play fetch. My dog is " + input3 + ".";
  }

  }
  }

  function reset(){
    document.getElementById("s1").innerHTML="";
  }

  function hide(){
    document.getElementById("s1").style.display= 'none';
    document.getElementById("r1").style.display= 'none';
  }
</script>

</head>
<body onload="hide()">

<table>
  <tr>
    <td> <input type="text" id="z1" placeholder="Your Dog's Name" name="name" maxlength="100"></td>
    <td> <select name="gender" id="z2"> <option value="" disabled selected>Select your dog's gender.</option> <option value="He">He</option> <option value="She">She</option> </select></td>
    <td> <select name="size" id="z3"> <option value="" disabled selected>Select your dog's size.</option> <option value="big">big</option> <option value="medium in size">medium</option> <option value="small in size">small</option> </select></td>
</table>
<br>
<div class="display">
  <button onclick="sentence()"> Submit </button>
</div>
<hr>
<br>
<textarea rows="10" cols="100" id="s1"></textarea>
<br>

<div class="display">
  <button onclick="reset()" id="r1">Reset</button>
</div>

</body>
</html>

1 Ответ

0 голосов
/ 30 июня 2018

Правильный способ чтения / записи в текстовое поле - использовать атрибут value, а не innerHTML. Читать HTMLTextAreaElement Reference

Код ниже работает,

function sentence() {
  document.getElementById("s1").value = "";// reset
  document.getElementById("s1").style.display = "block";
  document.getElementById("r1").style.display = "block";
  if (document.getElementById("z1").value == "") {
    alert("Hi! Your dog's name is required for submission.");
    document.getElementById("z1").focus();
  } else if (document.getElementById("z2").value == "") {
    alert("Hi! Your dog's gender is required for submission.");
  } else if (document.getElementById("z3").value == "") {
    alert("Hi! Your dog's size is required for submission.");
  } else {
    const input1 = document.getElementById("z1").value;
    const input2 = document.getElementById("z2").value;
    const input3 = document.getElementById("z3").value;
    document.getElementById("s1").value =
      "My dog's name is " +
      input1 +
      ". " +
      input2 +
      " loves to play fetch. My dog is " +
      input3 +
      ".";

  }
}

function reset() {
  document.getElementById("s1").value = "";
}

function hide() {
  document.getElementById("s1").style.display = "none";
  document.getElementById("r1").style.display = "none";
}
table,td,th {margin-left: auto;margin-right: auto}
  .display {display: flex;align-items: center;justify-content: center;}
  p {text-align: center;}
  textarea {display: block;margin-left:auto;margin-right: auto;}
<body onload="hide()">
  <table>
    <tr>
      <td> <input type="text" id="z1" placeholder="Your Dog's Name" name="name" maxlength="100"></td>
      <td> <select name="gender" id="z2"> <option value="" disabled selected>Select your dog's gender.</option> <option value="He">He</option> <option value="She">She</option> </select></td>
      <td> <select name="size" id="z3"> <option value="" disabled selected>Select your dog's size.</option> <option value="big">big</option> <option value="medium in size">medium</option> <option value="small in size">small</option> </select></td>
  </table>
  <br>
  <div class="display">
    <button onclick="sentence()"> Submit </button>
  </div>
  <hr>
  <br>
  <textarea rows="10" cols="100" id="s1">

</textarea>
  <br>

  <div class="display">
    <button onclick="reset()" id="r1">Reset</button>
  </div>

</body>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...