栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

html指令式tooltip文字提示,css实现,无脚本

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

html指令式tooltip文字提示,css实现,无脚本

直接上图

分析执行流程
  1. 鼠标移入节点
  2. 检测是该节点是否存在开启实现tooltip实现的标识(类名,属性等)
  3. 检测主题、位置(类名,属性等)
  4. 生成 / 显示气泡

借鉴他人

让我们先来看看element-ui的tooltip样式

很明显,气泡的位置是通过javascript脚本加上去的


不多逼逼,让我们来定几个期望
  1. 不用javascript脚本,纯css实现
  2. 不用添加新元素**(用after、before伪元素)**
  3. 不用类名匹配,直接用属性选择器**([attr])**
  4. 支持默认样式**(标签没定义主题、位置的时候)**
  5. 指令式**(直接在标签定义即可,接下来交给css匹配)**
  6. 实现气泡的主题、位置
  7. sass预处理器开发(看不懂的同学可以转换成css

html定义指令规范

指令式声明


  • tooltip — 气泡显示的内容
  • effect — 气泡的主题(dark / light),默认dark;
  • placement — 气泡相对于父元素的位置(top / top-left/ top-right / right / right-top/ right-bottom…),默认top;

先写几个按钮

样式借鉴element-ui

  
    
    
    
  
  
    
    
    
  
  
    
    
    
  
  
    
    
    
  

css核心代码逻辑实现

hover监听鼠标移入、移出,**[tooltip]**匹配有该属性的标签,after为气泡,before为三角形

[tooltip] {
  position: relative;

  
  &::after {
    display: none;
    content: attr(tooltip);
  }

  
  &::before {
    display: none;
    content: '';
  }

  
  &:hover {

    &::after {
      display: block;
    }

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

现在鼠标移入之后便有效果


为了方便看到效果,测试可以把气泡、三角形默认为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; 
}

定制气泡、三角形位置(只示例一个方向)


.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};
    }
  }
}

标签不存在placement 属性 / 为空的时候,默认继承top位置

&: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地址https://codepen.io/anon/pen/yRBXBY

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/242290.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号