Используйте css'content для реализации императивных текстовых подсказок во всплывающей подсказке.

CSS

прямо над

Анализировать процесс исполнения

  1. наведите указатель мыши на узел
  2. Обнаружение заключается в том, имеет ли узел открытую реализациюtooltipИдентификатор реализации (имя класса, свойства и т. д.)
  3. Обнаружение предмета, местоположения (имя класса, свойства и т. д.)
  4. Создать/показать пузыри

учиться у других

Давайте сначала посмотримelement-ui的tooltipстиль

Это понятно,气泡的位置черезjavascriptдобавлен


Давайте установим некоторые ожидания

  1. Не нужноjavascript,чистыйcssвыполнить;
  2. без добавления новых элементов(用after、before伪元素)
  3. Вместо сопоставления имен классов используйте селекторы атрибутов напрямую.[attr]
  4. Поддержка стиля по умолчанию (когда метка не определяет тему и местоположение)
  5. Императив (можно определить прямо в метке, а потом отдать вcssсоответствовать)
  6. Реализовать тему и положение пузыря
  7. использоватьsassразработка препроцессора

Спецификация директивы определения HTML

Императивное заявление:

<button tooltip='我是内容鸭' effect='light' placement='top-left'>上左</button>
  • tooltip— содержимое, отображаемое пузырем;
  • effect— тема пузырей (темная/светлая), по умолчанию темная;
  • placement— Положение пузырька относительно родительского элемента (сверху/сверху-слева/сверху-справа/справа/справа-сверху/справа-снизу...), по умолчанию сверху;

Напишите несколько кнопок

ссылка на стильelement-ui

<div class="container">
  <div class="top">
    <button tooltip="上边" placement="top-left" effect="light">上左</button>
    <button tooltip="上左上左" placement="top">上边</button>
    <button tooltip="上右" placement="top-right">上右</button>
  </div>
  <div class="left">
    <button tooltip="左上左上左上左上左上左上左上左上左上左上" placement="left-top">左上</button>
    <button tooltip="左边" placement="left" effect="light">左边</button>
    <button tooltip="左右" placement="left-bottom">左下</button>
  </div>
  <div class="right">
    <button tooltip="右上右上右上右上右上右上右上右上" placement="right-top">右上</button>
    <button tooltip="右边" placement="right" effect="light">右边</button>
    <button tooltip="右下" placement="right-bottom">右下</button>
  </div>
  <div class="bottom">
    <button tooltip="下左下左" placement="bottom-left">下左</button>
    <button tooltip="下边" placement="bottom" effect="light">下边</button>
    <button tooltip="下右" placement="bottom-right">下右</button>
  </div>
</div>

Реализация логики основного кода CSS

hoverСледите за движением мыши внутрь и наружу,[tooltip]сопоставляет теги с этим атрибутом,afterдля пузырей,beforeдля треугольника:

/* 匹配有tooltip属性的元素 */
[tooltip] {
  position: relative;

  /* 气泡默认样式 */
  &::after {
    display: none;
    content: attr(tooltip);
  }

  /* 三角形默认样式 */
  &::before {
    display: none;
    content: '';
  }

  /* 鼠标移入该元素,显示气泡、三角形 */
  &:hover {

    &::after {
      display: block;
    }

    &::before {
      display: block;
    }
  }
}

Теперь он имеет эффект при перемещении мыши.


Чтобы легко увидеть эффект, тест может установить пузыри и треугольники на блокировку по умолчанию.

/* 气泡默认样式 */
&::after {
  display: block;
  content: attr(tooltip);
}

/* 三角形默认样式 */
&::before {
  display: block;
  content: '';
}

Текущий эффект выглядит следующим образом:

Установите стиль по умолчанию для пузырьков и треугольников

Основной дисплей, конечно, установить абсолютное позиционирование:

/* 气泡默认样式 */
&::after {
  display: block;
  content: attr(tooltip);
  position: absolute;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 8px 15px;
  max-width: 200px;
  border-radius: 4px;
  box-shadow: 0 10px 20px -5px rgba(0, 0, 0, 0.4);
  z-index: 100;
  @extend .tooltip-theme-dark; /* 继承默认主题(黑底白字) */
 }

/* 三角形默认样式 */
&::before {
  display: block;
  content: '';
  position: absolute;
  border: 5px solid transparent;
  z-index: 100;
  @extend .triangle-theme-dark; /* 继承默认主题(黑底) */
}

Текущий эффект выглядит следующим образом:

Индивидуальный пузырь, цвет темы треугольника

Определите каждую из двух тем:

$white: #fff;
$black: #313131;

/* 气泡主题 */
.tooltip-theme-dark {
  color: $white;
  background-color: $black;
}

.tooltip-theme-light {
  color: $black;
  background-color: $white;
  border: 1px solid $black;
}

/* 三角形主题 */
.triangle-theme-dark {
  border-top-color: $black;
}

.triangle-theme-light {
  border-top-color: $black; /* 暂时跟dark一样 */
}

Настройте положение пузыря, треугольника (показано только одно направление)

/* 气泡位置 */

/*----上----*/
.tooltip-placement-top {
  bottom: calc(100% + 10px);
  left: 50%;
  transform: translate(-50%, 0);
}

.tooltip-placement-top-right {
  bottom: calc(100% + 10px);
  left: 100%;
  transform: translate(-100%, 0)
}

.tooltip-placement-top-left {
  bottom: calc(100% + 10px);
  left: 0;
  transform: translate(0, 0)
}

/* 三角形位置 */

/*----上----*/
.triangle-placement-top {
  bottom: calc(100% + 5px);
  left: 50%;
  transform: translate(-50%, 0);
}

.triangle-placement-top-left {
  bottom: calc(100% + 5px);
  left: 10px;
}

.triangle-placement-top-right {
  bottom: calc(100% + 5px);
  right: 10px;
}

Место съемки, тема

Это также самый основной код. Используйте селектор атрибутов, чтобы сопоставить значение на этикетке, а затем установите другие стили.

Соответствующие темы пузырьков, треугольников:

&[effect="light"] {
  &::after {
    @extend .tooltip-theme-light;
  }

  &::before {
    @extend .triangle-theme-light;
  }
}

Матч-пузырь, позиции треугольника, 12 позиций:

@each $placement in top,top-right,top-left,
right,right-top,right-bottom,
bottom,bottom-right,bottom-left,
left,left-top,left-bottom {
  &[placement="#{$placement}"] {
    &::after {
      @extend .tooltip-placement-#{$placement};
    }

    &::before {
      @extend .triangle-placement-#{$placement};
    }
  }
}

Когда метка не имеет атрибута размещения / пуста, верхняя позиция наследуется по умолчанию:

&:not([placement]),
&[placement=""] {
  &::after {
    @extend .tooltip-placement-top;
  }

  &::before {
    @extend .triangle-placement-top;
  }
}

Текущий эффект выглядит следующим образом:

Давайте сделаем текст длиннее и добавим стили пузырьков и треугольников по умолчанию.display:noneпосмотри:

добавить анимацию

Он разделен на четыре направления, вверх и вниз, влево и вправо и четыре анимации:


@keyframes anime-top {
  from {
    opacity: .5;
    bottom: 150%;
  }
}

@keyframes anime-bottom {
  from {
    opacity: .5;
    top: 150%;
  }
}

@keyframes anime-left {
  from {
    opacity: .5;
    right: 150%;
  }
}

@keyframes anime-right {
  from {
    opacity: .5;
    left: 150%;
  }
}

Чтобы сопоставить положение пузырька, чтобы определить, какую анимацию выполнять, используйте[attr^=]Выбор, такой как верхний левый, верхний правый, также может соответствовать:

/* 设置动画 */
@each $placement in top,
 right,
bottom,
left {
  &[placement^="#{$placement}"] {

    &::after,
    &::before {
      animation: anime-#{$placement} 300ms ease-out forwards;
    }
  }
}

Окончательный эффект выглядит следующим образом:

Прикрепить адрес codepenкод спрей.IO/anon/spray/с R…

наконец

Если вы считаете, что эта статья хороша, пожалуйста, не забудьте нажатьа также关注О~😊