Как сделать так, чтобы ввод радио, флажка и текстовой области отзывался? - PullRequest
0 голосов
/ 01 августа 2020

Код ниже был сделан в Codepen. Вот ссылка: https://codepen.io/andyzam/pen/mdVvrLB

Когда я изменяю размер окна, элементы в таблице изменяются правильно. Но переключатели, флажки и поля ввода остаются неизменными. Как мне заставить их переместиться?

Нужно ли мне что-то добавлять к идентификаторам #radio, #checkboxes и #textarea? Я попытался использовать # radio label {} и использовать другие свойства дисплея, но они все еще оставались неподвижными.

body{
  background: lightblue;
  font-family: monospace;
  margin: 0px;
}

p {
  text-align: center;
  font-size: 14px;
}

#title {
  text-align: center;
}

#description {
    margin-left: auto;
    margin-right: auto;
    width: 500px;
    font-size: 20px;
    text-align: justify;
    padding: 10px;
}

input {
  width: 250px;
}

label {
  font-size: 14px;
  margin-right: 0px;
}

table {
    margin-left: auto;
    margin-right: 35em;
}

td {
  text-align: right;
  width: 250px;
  padding: 10px;
}

input:invalid {
  border: 2px dashed red;
}

input:invalid:required {
  background-image: linear-gradient(to right, pink, white);
}

input:valid {
  border: 2px solid black;
}

select {
  width: 260px;
}

select:invalid:required {
  background-image: linear-gradient(to right, pink, white);
}

select:valid {
  border: 2px solid black;
}

#radio {
  display: block;
  margin-left: 53em;
  padding: 10px;
}


input[type="radio"] {
    width: 20px;
}

#checkboxes {
  display: block;
  margin-left: 53em;
  padding: 10px;
}

input[type="checkbox"] {
    width: 20px;
}

#text-field {
  display: block;
  margin-left: 45em;
  padding: 10px;
}

#submit-button {
text-align: center;
  padding: 20px;
}


<html>
  <body>
    <title>TikTok User Survey</title>
    <main>
      <h1 id="title">TikTok User Survey</h1>
      <p id="description">We are gathering information from various TikTok users to gauge their satisfaction with the social media platform.</p>
      <p> All fields are required.</p>
      <form id="survey-form">
        <table>
          <tr>
          <td><label for="name" id="name-label">Your name:</label></td>
            <td><input type="text" id="name" name="name-label" placeholder="Your Name" required></td>
          </tr>
          <tr>
            <td> <label for="email" id="email-label">Enter your email:</label></td>
            <td><input type="email" id="email" name="email" placeholder="Email" required></td>
          </tr>
          <tr>
            <td> <label for="number" id="number-label">How many followers:</label></td>
            <td><input type="number" id="number" name="number" placeholder="No. of Followers (0-100k)" required min="0" max="100000"></td>
          </tr>
          <tr>
            <td>
              <label for="age">How old are you?:</label></td>
            <td>
  <select id="dropdown" name="age" required>
    <option disabled selected value> -- select an option -- </option>
    <option value="under13">Under 13</option>
    <option value="13-20">13-20</option>
    <option value="20-30">20-30</option>
    <option value="over30">Over 30</option>
  </select>
            </td>
          </tr>
        </table>
        <p>My gender:</p>
        <div id='radio'>
          <input type="radio" id="male" name="gender" value="male">
            <label for="male">Male</label><br>
<input type="radio" id="female" name="gender" value="female">
  <label for="female">Female</label><br>
<input type="radio" id="other" name="gender" value="other">
  <label for="other">Other</label>
        </div>
        <p>Favorite types of videos:</p>
        <div id="checkboxes">
          <input type="checkbox" id="dancing" name="dancing" value="dancing">
<label for="dancing">Dancing</label><br>
<input type="checkbox" id="cooking" name="cooking" value="cooking">
<label for="cooking">Cooking</label><br>
<input type="checkbox" id="pranks" name="pranks" value="pranks">
<label for="pranks">Pranks</label><br>
        </div>
        <p>Any additional comments about what you like:</p>
        <div id="text-field">
          <textarea name="message" rows="10" cols="30">I also like....</textarea>
        </div>
        <div id="submit-button">
        <button type="submit" id="submit">Submit</button>
        </div>
      </form>
    </main>
  </body>
</html>

1 Ответ

3 голосов
/ 01 августа 2020
• 1000 1004 *
#description {
  margin-left: auto;
  margin-right: auto;
  width: 500px;
  font-size: 20px;
  text-align: justify;
  padding: 10px;
}

Однако еще лучшим способом может быть присвоение значения flexbox содержащему элементу, а затем вы можете центрировать элементы оттуда, если вы sh так их позиционируете .

.container {
  display: flex;
  justify-content: center;
  align-items: center;
}

Flexbox не определяется горизонтальным или вертикальным центрированием, так как вы можете изменить направление центрирования. Но в случае по умолчанию justify-content: center; будет центрироваться по горизонтали, а align-items: center; - по вертикали.

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

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