Как отобразить дочерний элемент ('.cylon') без указания высоты родителя - PullRequest
0 голосов
/ 25 сентября 2018

Кто-нибудь знает, как я могу получить дочерний элемент (.cylon) для отображения без указания высоты родительского элемента (.container) ?Я хочу, чтобы контейнер имел высоту жидкости, чтобы можно было полностью отобразить элемент результата (#result) .

// DOM elements
const minInput = document.getElementById("minInput");
const maxInput = document.getElementById("maxInput");
const generate = document.getElementById("generate");
const reset = document.getElementById("reset");
const result = document.getElementById("result");

generate.addEventListener("click", function() {
  // Determine the min and max number of the users input
  let min = Math.min(minInput.value, maxInput.value);
  let max = Math.max(minInput.value, maxInput.value);

  // Calculate a random number
  const randomNumber = Math.floor(Math.random() * (max - min + 1) + min);

  // Render random number to DOM
  result.textContent = `Random number: ( ${randomNumber} ) between ${min} and ${max}`;
});

// Reset elements
reset.addEventListener("click", function() {
  minInput.value = "";
  maxInput.value = "";
  result.textContent = "";

  minInput.focus();
});
*,
*:before,
*:after {
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

body {
  color: #fff;
  /* height: 100vh; */
  background-color: #191919;
}

.container {
  width: 100%;
  height: 245px;
  height: 100%;
  overflow: hidden;
  border-radius: 5px;
  background-color: #000;
}

.text {
  float: left;
  width: 100%;
  padding: 5px 20px;
}

.generator {
  width: 100%;
  display: grid;
  grid-gap: 1.3em;
  align-items: end;
  grid-template-columns: repeat(2, 1fr);
}

input {
  border: 0;
  height: 25px;
  width: 100%;
  padding-left: 5px;
  border-radius: 5px;
}

button {
  padding: 5px 0;
  color: #fff;
  background-color: transparent;
}

button:hover {
  cursor: pointer;
  background-color: rgb(29, 29, 29);
}

.cylon {
  width: 20%;
  height: 100%;
  background-color: red;
  background-image: -webkit-linear-gradient( left, rgba(0, 0, 0, 0.9) 25%, rgba(0, 0, 0, 0.1) 50%, rgba(0, 0, 0, 0.9) 75%);
  animation: move-eye 4s linear infinite alternate;
}

@keyframes move-eye {
  from {
    margin-left: -20%;
  }
  to {
    margin-left: 100%;
  }
}
<div class="container">
  <div class="text">
    <h1>Random number generator </h1>
    <div class="generator">
      <div class="box">
        <label for="min">Min</label>
        <input type="number" placeholder="Enter the minimum #" id="minInput">
      </div>

      <div class="box">
        <label for="max">Max</label>
        <input type="number" placeholder="Enter the maximum #" id="maxInput">
      </div>

      <button id="generate">Generate</button>
      <button id="reset">Reset</button>
    </div>

    <p id="result"></p>
  </div>

  <div class="cylon"></div>
</div>

1 Ответ

0 голосов
/ 25 сентября 2018

Быстрое решение здесь:

  1. Поместите некоторый текст в .cylon div

    <div class="cylon">any text</div>
    
  2. В вашем CSS добавьте стиль нижеto .cylon

    color: rgba(0,0,0,0);
    

Надеюсь, это поможет.

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