kl1mmm
@kl1mmm
Хто я?

Как реализовать анимированое выпадение части блока при клике на целевой элемент?

На моменте адаптации web-приложения под смартфоны и планшеты столкнулся с проблемой: не могу реализовать выпадение части блока, обведённой красным цветом, на скриншоте ниже при клике на гиперссылку (а) в которую зашита стрелочка и checkbox. При первом клике блок должен расширяться и выводяться имена пользователей, с прочей информацией... При повторном же, блок должен уменьшиться и вся данная информация должна скрыться.
В ходе моего анализа, я вывел теорию, что это связано с вложенностью checkbox-а и необходимого мне для сокрытия или открытия div-а.
Буду весьма благодарен за конструктивную помощь.

641f2001da50f091041652.png

HTML:
<div class="playersTable">
        <div class="topOfTable">
          <div class="tableName">Игроки</div>
          <div class="clickTop">
            <input class="checkbox" type="checkbox" @click="this.$refs.arr.classList.toggle('open');" name="" id=""/>
            <a class="arrow-icon" ref="arr" @click="this.$refs.arr.classList.toggle('open');">
              <span class="left-bar"></span>
              <span class="right-bar"></span>
            </a>
          </div>
        </div>
        <Table class="menu-items">
          <tbody>
          <tr v-for="player in playersData" :key="player.ID">
            <div class="row">
              <div class="column">
                <td><img alt="O" class="imgTeam" src="@/components/UI/pics/ZeroPlayer1.svg"
                         v-if="player.Team === 'Zero'">
                  <img alt="X" class="imgTeam" src="@/components/UI/pics/CrossPlayer2.svg"
                       v-if="player.Team === 'Cross'"></td>
                <td class="playerName">{{ player.PlayerName }}</td>
              </div>
              <td class="percent">{{ player.PercentOfWins }} побед</td>
            </div>
          </tr>
          </tbody>
        </Table>
      </div>


CSS:
@media screen and (max-width: 905px) {
  .screen {
    flex-direction: column;
  }

  .wrapper {
    background: #E5E5E5;
  }

  .topOfTable {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-content: center;
    margin: 1em 0.85em 0 0.85em;
  }

  .clickTop {
    position: relative;
    margin-right: 1.75em;
  }

  .row {
    margin-bottom: 2%;
    margin-left: 0.7em;
  }

  .playersTable {
    width: 90%;
  }

  menu-items {
    display: flex;
    transform: translateY(0);
    transition: transform 0.5s ease-in-out;
  }

  .playersTable input[type="checkbox"]:checked ~ .menu-items {
    transform: translateY(0);
  }

  .arrow-icon {
    height: 1em;
    width: 1em;
    display: block;
    padding: 0.5em;
    position: absolute;
    cursor: pointer;
    border-radius: 4px;
    margin-top: 10px;
  }

  .checkbox {
    display: block;
    position: absolute;
    z-index: 5;
    height: 1em;
    width: 1em;
    cursor: pointer;
    opacity: 0;
  }

  .left-bar {
    position: absolute;
    background-color: transparent;
    top: 0;
    right: 9px;
    width: 13px;
    height: 3px;
    display: block;
    transform: rotate(35deg);
    float: right;
    border-radius: 2px;
  }

  .left-bar:after {
    content: "";
    background-color: black;
    width: 13px;
    height: 3px;
    display: block;
    float: right;
    border-radius: 6px 10px 10px 6px;
    transition: all 0.5s cubic-bezier(0.25, 1.7, 0.35, 0.8);
    z-index: -1;
  }

  .right-bar {
    position: absolute;
    background-color: transparent;
    top: 0px;
    left: 0px;
    width: 13px;
    height: 3px;
    display: block;
    transform: rotate(-35deg);
    float: right;
    border-radius: 2px;
  }

  .right-bar:after {
    content: "";
    background-color: black;
    width: 13px;
    height: 3px;
    display: block;
    float: right;
    border-radius: 10px 6px 6px 10px;
    transition: all 0.5s cubic-bezier(0.25, 1.7, 0.35, 0.8);
    z-index: -1;
  }

  .open .left-bar:after {
    transform-origin: center center;
    transform: rotate(-70deg);
  }

  .open .right-bar:after {
    transform-origin: center center;
    transform: rotate(70deg);
  }
}
  • Вопрос задан
  • 61 просмотр
Решения вопроса 1
LenovoId
@LenovoId
svg, css,js


решить проблему с дублирующими блоками помогли : ruSO
Ответ написан
Комментировать
Пригласить эксперта
Ответы на вопрос 2
noder_ss
@noder_ss
Линуксоид-энтузиаст и SQL разработчик
Через js. По клику на кнопку открытия открываешь ранее созданный выпадающий список
Ответ написан
Комментировать
vovka3003
@vovka3003
Фрилансер. Инженер систем безопасности.
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 12:39
100000 руб./за проект
23 нояб. 2024, в 12:16
60000 руб./за проект
23 нояб. 2024, в 08:36
2000 руб./за проект