div+css实现带三角箭头提示框

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

 
 

这是一个提示框

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

首先来研究一下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。

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

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

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

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

 

2019.1.3更新

  最近在读《CSS揭秘》这本书,发现里面有许多好的方法与技巧自己还没掌握,目前浏览器对CSS的处理能力早已今非昔比,文章开头的效果可以用更简单的方式来实现,顺便记录一下 inherit 这个属性的用法,因为这个属性确实被我忽视了好久,用的好可以提升很多效率。

.callout { 
    position: relative; 
    width:300px;
    height:200px;
    border:1px solid #e0e;
    background:#ece;
    border-radius:.3em;
}
.callout::before {
   content: "";
   position: absolute;
   top: -.41em; 
   left: 1em;
   padding: .35em;
   background: inherit;
   border: inherit;
   border-right: 0;
   border-bottom: 0;
   transform: rotate(45deg);
}

 

 

inherit不仅能继承父元素的颜色,甚至连边框样式都继承下来了,另外,css中还有一个currentColor变量也是非常好用的。

 

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

转载请注明出处。

posted @ 2012-09-24 17:44  逐影  阅读(3880)  评论(9编辑  收藏  举报