прямо над
Анализировать процесс исполнения
- наведите указатель мыши на узел
- Обнаружение заключается в том, имеет ли узел открытую реализацию
tooltip
Идентификатор реализации (имя класса, свойства и т. д.) - Обнаружение предмета, местоположения (имя класса, свойства и т. д.)
- Создать/показать пузыри
учиться у других
Давайте сначала посмотримelement-ui的tooltip
стиль
Это понятно,气泡的位置
черезjavascript
добавлен
Давайте установим некоторые ожидания
- Не нужно
javascript
,чистыйcss
выполнить; - без добавления новых элементов
(用after、before伪元素)
- Вместо сопоставления имен классов используйте селекторы атрибутов напрямую.
[attr]
- Поддержка стиля по умолчанию (когда метка не определяет тему и местоположение)
- Императив (можно определить прямо в метке, а потом отдать в
css
соответствовать) - Реализовать тему и положение пузыря
- использовать
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…
наконец
Если вы считаете, что эта статья хороша, пожалуйста, не забудьте нажать赞
а также关注
О~😊