Подтвердить что ты не робот

CSS отзывчивые плавающие всплывающие подсказки - невозможно?

Я пытаюсь сделать всплывающие подсказки в чистом css, и я бы хотел, чтобы они были отзывчивыми, то есть они должны плавать внутри и там, где нет места на левой стороне, они должны отображаться справа или сверху или снизу.

Я пытаюсь что-то вроде этого

Fiddle

span {
  position: relative;
}
div {
  margin: 150px 100px 50px 50px;
  border: 1px solid Black;
  height: 100px;
}
left,
right,
bottom,
top {
  position: absolute;
  background: black;
  color: white;
  max-width: 90px;
}
left {
  left: 0;
}
right {
  right: 0;
}
bottom {
  margin: 0 auto;
  bottom: 0;
  left: 0;
  right: 0;
}
top {
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
}
<span>
<div>
    <top>
        TOP
    </top>
    
    <bottom>
        BOTTOM
    </bottom>
    
    <right>
        RIGHT
    </right>
    
    <left>
        LEFT
    </left>
</div>
</span>
4b9b3361

Ответ 1

Из того, что я понимаю, вы все делаете хорошо, но вы просто забываете, что ваш родитель является встроенным элементом (<span>), поэтому вы должны установить его как display:inline-block/block для работы.

От MDN

Элементы HTML (язык гипертекстовой разметки) обычно являются "встроенными", элементов или элементов уровня блока. Встроенный элемент занимает только пространство, ограниченное тегами, которые определяют встроенный элемент. Элементы

Следующие элементы являются "inline":

b, big, i, small, tt
abbr, acronym, cite, code, dfn, em, kbd, strong, samp, time, var
a, bdo, br, img, map, object, q, script, span, sub, sup
button, input, label, select, textarea

Итак, имея в виду, что ваша скрипка будет примерно такой:

Отрывок

span {
  position: relative;
  display: block
}
div {
  margin: 150px 100px 50px 50px;
  border: 1px solid Black;
  height: 100px;
}
left,
right,
bottom,
top {
  position: absolute;
  background: black;
  color: white;
  max-width: 90px;
}
left {
  left: 0;
}
right {
  right: 0;
}
bottom {
  margin: 0 auto;
  bottom: 0;
  left: 0;
  right: 0;
}
top {
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
}
<span>
<div>
    <top>
        TOP
    </top>
    
    <bottom>
        BOTTOM
    </bottom>
    
    <right>
        RIGHT
    </right>
    
    <left>
        LEFT
    </left>
</div>
</span>

Ответ 2

Вот полностью отзывчивая подсказка или модальная форма, которая не использует javascript. (внешняя ссылка на Codepen) Вы можете активировать всплывающее окно, наведя или щелкнув.

Если вы наводите курсор, всплывающее окно будет отклонено после того, как оно потеряет фокус (это типичное поведение на рабочем столе для всплывающей подсказки).

Вы также можете щелкнуть логотип, который будет создан для запуска всплывающего окна на мобильном устройстве. Если вы активировали всплывающее окно с помощью щелчка, всплывающее окно останется открытым до тех пор, пока вы не нажмете всплывающее окно второй раз, чтобы отклонить его. (Это тип поведения, который вы испытываете на мобильном устройстве с помощью всплывающей подсказки или модального окна).

Это не использует javascript, используя псевдо-атрибут CSS :target и pointer-events. Для классов :hover и :active я использовал общий селектор и непосредственный селектор, потому что в некотором браузере есть известная ошибка, когда вы комбинируете использование псевдоселекторов в паре с селекторами для сиблинга.

.badge {
  position: relative;
  width: 300px;
  text-align: center;
  user-select: none;
  -webkit-transform: translateZ(0);
}
.logo {
  background-image: url('');
  width: 200px;
  height: 200px;
  cursor: pointer;
  display: block;
  margin: 0 auto
}
#trigger a {
  display: block;
  height: 100%;
  width: 100%;
}
.dialog {
  background: #fff;
  bottom: 100%;
  color: #666;
  display: block;
  left: -25px;
  opacity: 0;
  padding: 25px;
  pointer-events: none;
  position: absolute;
  width: 100%;
  transform: translateY(10px);
  transition: all .25s ease-out;
}
#trigger:hover ~ .dialog,
#trigger:hover + .dialog #trigger:active ~ .dialog,
#trigger:active + .dialog {
  opacity: 1;
}
.dialog:target {
  opacity: 1;
  pointer-events: auto;
}
.close.box {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  color: inherit;
  text-decoration: none;
}
<div class="badge" style="margin-top:150px;">
  <div id="trigger" class="logo">
    <a href="#open1">&nbsp;</a>
  </div>
  <div id="open1" class="dialog">
    <a href="#close" title="Close" class="close box"></a>
    <h2>Tooltip</h2>

    <p>Click this tooltip to dismiss.</p>

  </div>
</div>

Ответ 3

Я думаю, что это невозможно, но у меня есть некоторые хорошие функции, которые помогут вам использовать чистые css.

Получить содержимое заголовка из атрибута и methon calc(); в css3

div.main {
        margin:150px 100px 50px 50px;
        border: 1px solid Black;
        height:100px;
      position: relative;
    }
    div.main div {
        position: absolute;
        background:black;
        color:white;
        max-width:90px;
        text-align: center;
        cursor: default;
    }
    .left {
        left:0;
    }
    .right {
        right:0;
    }
    .bottom {
        margin:0 auto;
        bottom:0;
        left:0;
        right:0;
    }
    .top {
     margin:0 auto;
        top:0;
        left:0;
        right:0;
    }
    div div.left:hover:after, div div.bottom:hover:after {
      right: auto;
    }
    div div:hover:after {
      content: attr(title);
      position: absolute;
      bottom: calc(100% + 8px);
      min-width: 100%!important;
      padding: 1px 6px;
      box-sizing: border-box;
      color: #304957;
      left: 0;
      right: 0;
      background: #C5E1F0;
      text-align: center;
      border: 1px solid #86AEC4;
    }
    div div:hover:before {
      width: 0;
      height: 0;
      border-style: solid;
      border-width: 6px 6px 0 6px;
      border-color: #304957 transparent transparent transparent;
      content: '';
      position: absolute;
      top: -8px;
      left: 50%;
      margin-left: -6px;
    }

<div class="main">
    <div class="top" title="WopTop WopTop WopTop  WopTop WopTop">
        TOP
    </div>

    <div class="bottom" title="ZafKopZafKopZafKop ZafKop ZafKopZafKop ZafKopZafKopZafKop">
        BOTTOM
    </div>

    <div class="right" title="Willy">
        RIGHT
    </div>

    <div  class="left" title="Garbuzov">
        LEFT
    </div>
</div>