Что нового

Бесплатно Красивый атрибут для TITLE (Tooltip)

Dmitriu99

Посетитель
Регистрация
20 Авг 2022
Сообщения
15
Реакции
20
Не знал куда лучше выложить данный стиль title (Tooltip с красивой анимацией появления), а точнее в какой раздел, по этому выложу сюда. (если что админ переместит)
Может кто искал, что-то похожее или увидит данную тему и решит реализовать себе.

Выглядит он таким вот образом, а так же значения можно выставить в любую сторону кодом (flow="right" - left, down, если нужно вверх не вписываем данную строчку)

ScreenRecorderProject1.gif
Используется не стандартный метод title, а tooltip.

Код вставки:
tooltip="Ваш текст" flow="right"
CSS:
/* TOOLTIP STYLES */
[tooltip] {
  position: relative; /* opinion 1 */
}

[tooltip]::before,
[tooltip]::after {
  text-transform: none; /* opinion 2 */
  font-size: .9em; /* opinion 3 */
  line-height: 1;
  user-select: none;
  pointer-events: none;
  position: absolute;
  display: none;
  opacity: 0;
}
[tooltip]::before {
  content: '';
  border: 5px solid transparent; /* opinion 4 */
  z-index: 1001; /* absurdity 1 */
}
[tooltip]::after {
  content: attr(tooltip);
  font-family: Helvetica, sans-serif;
  text-align: center;
  min-width: 3em;
  max-width: 21em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 1ch 1.5ch;
  border-radius: .3ch;
  box-shadow: 0 1em 2em -.5em rgba(0, 0, 0, 0.35);
  background: #4A4E57;
  color: #fff;
  z-index: 1000;
}

[tooltip]:hover::before,
[tooltip]:hover::after {
  display: block;
}

[tooltip='']::before,
[tooltip='']::after {
  display: none !important;
}

[tooltip]:not([flow])::before,
[tooltip][flow^="up"]::before {
  bottom: 100%;
  border-bottom-width: 0;
  border-top-color: #4A4E57;
}
[tooltip]:not([flow])::after,
[tooltip][flow^="up"]::after {
  bottom: calc(100% + 5px);
}
[tooltip]:not([flow])::before,
[tooltip]:not([flow])::after,
[tooltip][flow^="up"]::before,
[tooltip][flow^="up"]::after {
  left: 50%;
  transform: translate(-50%, -.5em);
}

[tooltip][flow^="down"]::before {
  top: 100%;
  border-top-width: 0;
  border-bottom-color: #4A4E57;
}
[tooltip][flow^="down"]::after {
  top: calc(100% + 5px);
}
[tooltip][flow^="down"]::before,
[tooltip][flow^="down"]::after {
  left: 50%;
  transform: translate(-50%, .5em);
}

[tooltip][flow^="left"]::before {
  top: 50%;
  border-right-width: 0;
  border-left-color: #4A4E57;
  left: calc(0em - 5px);
  transform: translate(-.5em, -50%);
}
[tooltip][flow^="left"]::after {
  top: 50%;
  right: calc(100% + 5px);
  transform: translate(-.5em, -50%);
}

[tooltip][flow^="right"]::before {
  top: 50%;
  border-left-width: 0;
  border-right-color: #4A4E57;
  right: calc(0em - 5px);
  transform: translate(.5em, -50%);
}
[tooltip][flow^="right"]::after {
  top: 50%;
  left: calc(100% + 5px);
  transform: translate(.5em, -50%);
}

@keyframes tooltips-vert {
  to {
    opacity: .9;
    transform: translate(-50%, 0);
  }
}

@keyframes tooltips-horz {
  to {
    opacity: .9;
    transform: translate(0, -50%);
  }
}

[tooltip]:not([flow]):hover::before,
[tooltip]:not([flow]):hover::after,
[tooltip][flow^="up"]:hover::before,
[tooltip][flow^="up"]:hover::after,
[tooltip][flow^="down"]:hover::before,
[tooltip][flow^="down"]:hover::after {
  animation: tooltips-vert 300ms ease-out forwards;
}

[tooltip][flow^="left"]:hover::before,
[tooltip][flow^="left"]:hover::after,
[tooltip][flow^="right"]:hover::before,
[tooltip][flow^="right"]:hover::after {
  animation: tooltips-horz 300ms ease-out forwards;
}
!!Если криво отображается или стиль не такой как на изображении, найдите в своих стиля [tooltip] и удалите.
 
Последнее редактирование:
лет 5-10+ назад помню было много JS библиотек отдельных для этого, но т.к. большая доля пользователей сейчас сидят в телефонах и планшетах, то лишним кодом можно и не грузить даже страницу, всем "плевать" какой текст будет при наведении по ссылке, главное - анкор ссылки и чтоб нужный материал был открыт при переходе по ней.
 
лет 5-10+ назад помню было много JS библиотек отдельных для этого, но т.к. большая доля пользователей сейчас сидят в телефонах и планшетах, то лишним кодом можно и не грузить даже страницу, всем "плевать" какой текст будет при наведении по ссылке, главное - анкор ссылки и чтоб нужный материал был открыт при переходе по ней.
С одной стороны как бы и да, но с другой, небольшой код css сильно не загрузит ваш сайт, тем более на телефоне прекрасно работает при нажатии.
Тем более. если помудрить немного, можно добавить например изображения актера при наведении
photo_2022-08-22_15-01-10.jpg
 
Отличная тема. Как то искал давно, но небыло ничего толкового.
Самое то для вывода полного заголовка, так как во многих шаблонах он просто обрезан по ширине постера.
Да и вообще, много где может пригодиться!
Один момент только нужно решить. На скриншотах вывод рядом, а у меня по факту слишком далеко. В какой строке подправить ?
 
Отличная тема. Как то искал давно, но небыло ничего толкового.
Самое то для вывода полного заголовка, так как во многих шаблонах он просто обрезан по ширине постера.
Да и вообще, много где может пригодиться!
Один момент только нужно решить. На скриншотах вывод рядом, а у меня по факту слишком далеко. В какой строке подправить ?
Вывод идёт от центра текста, блока и т.д. - если получается не по центру, значит отображается от блока (как пример), который по ширине больше чем то, что внутри него, например блок в ширину идёт 70px, а текст внутри него расположен внутри справа в блоке в ширину 40 px, оно будет выводить по середине блока, если стиль установлен именно в блок, а не в текст.

Пример, первое выводиться по середине блока, второй выводить так же посередине блока, только внутри него иконки смещены в лево стилями.
Скриншот 23-08-2022 22.07.20.pngСкриншот 23-08-2022 22.07.08.png
Сам уже запутался немного, в общем найди точное место куда нужно вставить данный код, выше пример когда стоит в блоке, ниже когда в самом элементе.
Скриншот 23-08-2022 22.18.31.png
 
Последнее редактирование:
Вывод идёт от центра текста, блока и т.д. - если получается не по центру, значит отображается от блока (как пример), который по ширине больше чем то, что внутри него, например блок в ширину идёт 70px, а текст внутри него расположен внутри справа в блоке в ширину 40 px, оно будет выводить по середине блока, если стиль установлен именно в блок, а не в текст.

Пример, первое выводиться по середине блока, второй выводить так же посередине блока, только внутри него иконки смещены в лево стилями.
Посмотреть вложение 1903Посмотреть вложение 1904
Сам уже запутался немного, в общем найди точное место куда нужно вставить данный код, выше пример когда стоит в блоке, ниже когда в самом элементе.
Посмотреть вложение 1905
Ок, понятно.
 
Спасибо, буквально пару недель назад искал для сайта.... Даже страницу в закладки добавлю:)
 
Верх