@Bot010

Как сделать такой элемент при наведений?

Как сделать что бы наведений на элемент появлялась это?60d9d4459ac77010001910.png
  • Вопрос задан
  • 320 просмотров
Решения вопроса 2
Neobezatelno
@Neobezatelno
Дюшес
Ответ написан
Комментировать
Fragster
@Fragster
помогло? отметь решением!
Z0cQxT1.png
с такой нарезкой попроще стало?

что-то типа такого: https://jsfiddle.net/Lsu6venk/
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
Ankhena
@Ankhena Куратор тега CSS
Нежно люблю верстку
Поскольку у ссылок есть иконки и они, вероятно, будут сделаны с помощью псевдо, то подумала, что нужно придумать решение с помощью только одного псевдоэлемента. Да и вообще, раз можно одним, то зачем писать два..



код

<nav>
  <ul>
    <li><a href="">link</a></li>
    <li><a href="">link</a></li>
    <li><a href="">link</a></li>
    <li><a href="">link</a></li>
    <li><a href="">link</a></li>
  </ul>
</nav>


nav {
  width: 200px;
  background: #92aef4;
}

ul {
  --color: white;
  --radius: 30px;
  --smoothing-radius: 29.4px;
  border-right: 10px solid var(--color);
  padding: 0 0 2em 1em;
  list-style-type: none;
}

a {
  position: relative;
  display: block;
  padding: 0.5em;
  border-radius: var(--radius) 0 0 var(--radius);
  text-decoration: none;
  color: #6704f2;
}

a::before {
  content: "❄ ";
  color: white;
}

a:hover::before {
  color: deeppink;
}

a:hover {
  background: var(--color);
}

a:hover::after {
  content: "";
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: var(--radius);
  height: calc(100% + 2 * var(--radius));
}

li:not(:last-child):not(:first-child) a:hover::after {
  background: radial-gradient(at top left, transparent var(--smoothing-radius), var(--color) var(--radius)) no-repeat top right / var(--radius) var(--radius),
    radial-gradient(at bottom left, transparent var(--smoothing-radius), var(--color) var(--radius)) no-repeat bottom 0 right 0 / var(--radius) var(--radius);
}

li:first-child a:hover::after {
  background: radial-gradient(at bottom left, transparent var(--smoothing-radius), var(--color) var(--radius)) no-repeat bottom 0 right 0 / var(--radius) var(--radius);
}

li:last-child a:hover::after {
  background: radial-gradient(at top left, transparent var(--smoothing-radius), var(--color) var(--radius)) no-repeat top right / var(--radius) var(--radius);
}
body {
  padding: 50px;
  margin: 0;
  font-size: 20px;
  font-family: 'Neucha', cursive;
  background: #eee;
}

Ответ написан
Комментировать
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы