css写对话框样式

  • Post author:
  • Post category:其他


<div class=”tooltip”>

<p>我是对话框</p>

<span class=”triangle”></span>

</div>

.tooltip {
    position: relative;
    background-color: silver;
    width: 200upx;
    height: 50upx;
    border-radius: 0.25em;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 200;
}
.triangle {
    display: block;
    border: 10upx solid transparent;
    border-top-color: silver;
    position: absolute;
    bottom: -20upx;
    left: calc(50% - 10upx);
}

效果如下:

但是还有问题

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

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

样式残缺


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个像素的圆角。



版权声明:本文为dakache11原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。