• 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-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变量也是非常好用的。

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

    转载请注明出处。

  • 相关阅读:
    Python运算符及逻辑运算
    Python编码、流程控制、格式化输出
    Docker私有仓库Harbor部署与使用
    react
    理事会
    关于elementui form表单过长,看不到未填项
    js
    vue 父子传值
    养生
    html知识点
  • 原文地址:https://www.cnblogs.com/undefined000/p/2700426.html
Copyright © 2020-2023  润新知