分享

div+css实现带三角箭头提示框 | 学步园

 日月桃子 2016-02-18

带三角箭头的提示框,就是下面所示:

这是一个提示框

通常我们都用图片来实现上面那个小三角,因为这样方便快速,但是如果图片处理得不好,会看起来有杂边,从而影响视觉,所以换一种思路来解决。

首先来研究一下CSS是如何实现三角形的。

假定有一个盒子(div),给定宽高分别为100像素,再给定边框50像素,那么它看起来会是下面这个样子(为了更直观,给了边框四种不同的颜色):

 

接下来,把盒子的高度设为0:

再把宽度也设为0:

这样雏形就已经出来了,由于IE6的bug(高度为0的div会有一定默认的高度,我的电脑上测量结果为19像素),需要做一些小调整,给div加一个overflow:hidden,IE6就能正确解析了。

接下来的工作就是去掉其余的三个边框。以向上箭头为例,假如我想让箭头朝上,那么就需要将左、上、右三条边框的颜色给去掉。一个常规的方法是将这三条边框的颜色设为透明,即transparent属性。

border-color:transparent transparent #056F61

设置以后可以看到如下效果:

这样CSS制作的三角形就完成了。到这里看起来工作好像差不多可以结束的样子,还需要测试一下浏览器的兼容性,经过测试,主流浏览器都支持,但是打开IE6,结果悲催了,居然是这个样子(T-T) :

排查一下哪个地方出了问题,才发现原来IE6不支持transparent属性,如之奈何?前面已经做了这么多工作,总不能倒在IE6下吧。

于是上网查了一下IE6支持transparent的方法,结果是需要使用滤镜。不过这个方案肯定不行,要使用滤镜的话,还不如直接用图片。之后再研究了一下,

发现如果将其余三条边的属性由solid改为dotted或者dashed就可以了:

/*border-style:solid*/
border-style:dotted dotted solid;
border-width:50px;
border-color:transparent transparent #056f61; 

这样看起来IE6就“支持”transparent属性了。为什么会这样呢?这个问题我还没搞明白。经过测试发现,如果将盒子的边框类型设置为dashed,在IE6下会有一个奇特的行为:

当盒子的宽高为100像素,边框的宽度为34像素且类型为dashed时,边框就会消失,设为33像素时又显示了,而且这个比例是一定的。

这也许就解释了为什么将边框类型改为dashed时IE6显示“正常”了。

当边框类型为dotted时,IE6显示如下:

将盒子的宽高设为0时黑点消失,此时IE6也显示“正常”了。

虽然IE6的解析可能有问题,但是总算“解决”了其不支持transparent的bug。

接下来的工作就很简单了,如法炮制一个三角形,背景和提示框一致,将其叠加到之前的三角形上,只留一像素的边,再将其定位到提示框上。

可以根据需求制作左右和下边的三角。

以上是个人的一些心得体会,如果有不对的地方还请各位指正。

源码: 带三角箭头的提示框

------------------------------

转载请注明出处。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多