相关文章推荐
销魂的风衣  ·  Android ...·  2 月前    · 
踏实的韭菜  ·  # 160_技巧_Power BI ...·  1 年前    · 

对话框小尾巴,估计大家在实际开发中应该经常遇到过,省事点的就是叫设计小姐姐给切个带小尾巴的背景图,那不省事的呢?

边框的魔法

在css3出来之前,若通过css来实现小尾巴效果,可能使用最多的是通过如下的hack方式:

<div class="tooltip">
    <p>我是快乐的小尾巴的爸爸</p>
    <span class="triangle"></span>
</div>
复制代码
 .tooltip {
    position: relative;
    background-color: silver;
    width: 200px;
    height: 50px;
    border-radius: 0.25em;
    display: flex;
    justify-content: center;
    align-items: center;
    border:1px solid red;
.triangle {
    display: block;
    height: 0px;
    width: 0px;
    border: 10px solid transparent;
    border-top-color: silver;
    background:red;
    position: absolute;
    bottom: -20px;
    left: calc(50% - 10px);
复制代码

效果如下:

不设置 triangle 宽高,设置 border 10像素的透明边框,然后设置 top 方向边框颜色和父元素一致就可完成这样的效果,同理,变换小尾巴箭头方向只需要在top,bottom,left,right方向上单独设置不同的边框颜色即可。

这种方式是挺奇妙的,但存在以下几个问题:

  • 如果父元素 tooltip 设置边框颜色,小尾巴颜色就法设置了,因为小尾巴本身就是通过边框魔法实现的
  • 小尾巴无法继承父元素的背景色,如果父元素背景色变化了,小尾巴得重新设置颜色
  • 小尾巴的形状无法支持多样化,比如下次我们想换个圆角的小尾巴,这种方式就无法实现了
  • 被咬了一口的样式,残缺的美~

    clip-path

    针对以上问题,现在有了一种特别好的方式,就是通过css3新增的 clip-path 属性来实现

    clip-path属性可以创建一个只有元素的部分区域可以显示的剪切区域,区域内的部分显示,区域外的隐藏

    css代码如下:

    .triangle {
        display: block;
        height: 20px;
        width: 20px;
        background-color: inherit;
        border: inherit;
        position: absolute;
        bottom: -10px;
        left: calc(50% - 10px);
        // ---关键代码 start---
        clip-path: polygon(0% 0%, 100% 100%, 0% 100%);
        transform: rotate(-45deg);
        // ---end---
        border-radius: 0 0 0 2px;
    复制代码

    我们可以看到 triangle 继承了父元素 tooltip 的边框颜色以及背景色,同时我们还设置了小尾巴2个像素的圆角。

    其中 polygon 多边形的坐标如下:

    深绿色块就是我们要显示的区域,然后逆时针翻转45度就成了我们想要的样式。

    多么好的方式呀!

    那浏览器兼容性如何呢?我查看了下 Caniuse 这个网站,除了老IE基本其它浏览器都支持,所以开心的用起来吧!

    最后提供一个 sass 的mixin,参数是上下左右四个方向。

    @mixin triangleMixin ($direction) {
      background-color: inherit;
      border: inherit;
      clip-path: polygon(0% 0%, 100% 100%, 0% 100%);
      @if( $direction == left ) {
        transform: rotate(45deg);
      } @else if( $direction == right ) {
        transform: rotate(-135deg);
      } @else if( $direction == down ) {
        transform: rotate(-45deg);
      } @else {
        transform: rotate(135deg);
    复制代码
    分类:
    前端