Альтернативные способы комбинирования отображения: нет и отображение: flex - PullRequest
0 голосов
/ 03 июля 2018

У меня была проблема с объединением display: none и display: flex. Я знаю, что есть много вопросов по этому поводу. Тем не менее, я хотел бы поделиться определенным образом об этом. Меня это не удовлетворяет полностью, потому что анимации несовместимы с . Вот что я сделал:

  • У меня есть один div, который я хочу сначала спрятать и переключать при нажатии (другого div). Таким образом, скрытый div (navigation) должен сначала иметь display: none, а затем при переключении он должен иметь display: flex
  • При (navi) щелчке класс переключается (shown), а в css, показанном, имеет свойства display: flex, а другой для целей размещения пространства
  • Проблема в том, что переключение классов включает добавление анимации

Вот минимальный пример:

$(document).ready(function() {
  $(".navi").click(function() {
    $(".navi .fa-chevron-down").toggleClass("rotate180");
    $(".navigation").toggleClass("shown")
  });
});
:root {
  --bg: mistyrose;
  --accent-light: #f67e7d;
  --accent-dark: #A94645;
  --accent-cont: #fff;
  --text: #371C1C;
}

body {
  background: var(--bg);
  font-family: helvetica, sans-serif;
  margin: 0;
  padding: 0;
  color: var(--text);
  font-size: 0.8em;
}

/* Navigation */

.navi {
  cursor: pointer;
  position: fixed;
  top: calc(10px + 7vh);
  left: 7vw;
  width: 14vw;
  min-width: 160px;
  line-height: 30px;
  border-radius: 5px;
  overflow: hidden;
  background: var(--accent-light);
  text-align: center;
}

.navi i {
  margin-left: 4.5vw;
  line-height: 30px;
}

.navi .fa-chevron-down {
  -webkit-transition: all 0.7s ease;
  -moz-transition: all 0.7s ease;
  -ms-transition: all 0.7s ease;
  -o-transition: all 0.7s ease;
  transition: all 0.7s ease;
}

.rotate180 {
  transform: rotate(180deg);
}

.navigation {
  position: absolute;
  top: calc(30px + 12vh);
  left: 7vw;
  width: 14vw;
  min-width: 160px;
  height: 24vh;
  min-height: 200px;
  border-radius: 5px;
  background: var(--accent-light);
  display: none;
}

.shown {
  display: flex;
  flex-wrap: wrap;
}

.navigation a {
  text-decoration: none;
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-evenly;
  align-items: center;
}

.navigation span {
  color: var(--accent-cont);
  text-align: center;
  -webkit-transition: all 0.3s ease;
  -moz-transition: all 0.3s ease;
  -o-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

.navigation a:hover i {
  -webkit-transform: rotate(360deg);
  -moz-transform: rotate(360deg);
  -ms-transform: rotate(360deg);
  -o-transform: rotate(360deg);
  transform: rotate(360deg);
  color: var(--accent-cont) !important;
}

.navigation a:hover span {
  color: var(--text);
}

.navigation i {
  display: block;
  color: var(--text) !important;
  font-size: 20px;
  margin: 0px 10px -10px 10px;
  padding: 5px;
  -webkit-transition: all 0.5s ease-in-out;
  -moz-transition: all 0.5s ease-in-out;
  -o-transition: all 0.5s ease-in-out;
  transition: all 0.5s ease-in-out;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<head>

  <link href="//maxcdn.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">

</head>

<body>

  <div class="navi"> NAVIGATION <i class="fa fa-chevron-down"></i></div>

  <!--Navigation-->
  <div class="navigation">

    <a href="{text:Link One Url}"><i class="fa fa-user-circle"></i><span>About</span></a>
    <a href="{text:Link Two Url}"><i class="fa fa-question-circle"></i><span>Answers</span></a>
    <a href="{text:Link Nine Url}"><i class="fa fa-folder-open-o"></i><span>Files</span></a>
    <a href="{text:Link Three Url}"><i class="fa fa-star"></i><span>Favorites</span></a>
    <a href="{text:Link Four Url}"><i class="fa fa-film"></i><span>Movies</span></a>
    <a href="{text:Link Eight Url}"><i class="fa fa-link"></i><span>Links</span></a>
    <a href="{text:Twitter url}" target="_blank"><i class="fa fa-twitter-square"></i><span>Twitter</span></a>
    <a href="{text:Instagram url}" target="_blank"><i class="fa fa-instagram"></i><span>Instagram</span></a>
    <a href="{text:Youtube url}" target="_blank"><i class="fa fa-youtube"></i><span>Youtube</span></a>

  </div>
  <!--End Navigation-->


</body>

И здесь - это jsfiddle, если проще.


Так что я действительно спрашиваю, может быть, есть альтернативный способ? Я пытался поместить атрибут hidden, но он не имел никакого эффекта и сначала переключал, а затем переключал отображение с блока на flex, но он выглядит неправильно с плитками и т. Д. Если у вас есть другое решение, я был бы рад услышать, спасибо!

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