div+css实现带三角箭头提示框
2012-10-12 17:47
686 查看
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。
接下来的工作就很简单了,如法炮制一个三角形,背景和提示框一致,将其叠加到之前的三角形上,只留一像素的边,再将其定位到提示框上。
可以根据需求制作左右和下边的三角。
相关文章推荐
- div+css实现带三角箭头提示框
- div+css实现带三角箭头提示框
- CSS实现带箭头的DIV(鼠标放上显示提示框)
- div+css实现圆形div以及带箭头提示框效果
- div+css实现的小三角tip小提示(原理及代码)
- css 提示框 CSS实现带箭头的DIV提示框
- CSS实现带箭头的提示框及鼠标在按钮与提示框上提示框不隐藏的Javascript的实现
- CSS实现带箭头的DIV
- 纯CSS实现小三角提示信息
- css实现三角箭头
- css实现对话框-带箭头提示框
- DIV+CSS实现的小三角
- css实现三角箭头(兼容IE6)
- javascript和css实现垂直方向自适应的三角提示菜单
- 纯CSS实现箭头、气泡让提示功能具有三角形图标(简单实例)
- 纯css实现进度状态条上箭头三角样式(附图)
- css实现的交互小三角箭头图标
- 纯CSS实现箭头、气泡让提示功能具有三角形图标
- 纯CSS实现tooltip提示框,CSS箭头及形状
- 纯CSS实现tooltip提示框,CSS箭头及形状