zoukankan      html  css  js  c++  java
  • css border 三角形阴影(不规则图形阴影) & 多重边框的制作

    前言:这是笔者学习之后自己的理解与整理。如果有错误或者疑问的地方,请大家指正,我会持续更新!

    border 的组合写法

      border:border-width border-style border-color;

    • border-width:边框宽度,不能为百分比,因为不会根据设备宽度改变;同理,outline | text-shadow | box-shadow 也不可以;
    • border-style:边框样式,一般用 solid 多一点,dashed(虚线)、dotted(点状线)也有;
    • border-color:边框颜色,默认颜色是元素的文本颜色,如果没有设置,那就从父元素继承文本颜色;

      边框可以根据方向单独设置,上下左右,border-top | border-bottom | border-left | border-right ;

      所以属性也可以单独设置,border-top-width | border-top-style | border-top-color ;

      单属性也可以有组合写法:

    • border-上   右   下   左;(顺时针方向)
    • border-上   左右   下;
    • border-上下   左右 ;
    • border-四个方向;
    • border-style | border-color也可以这样设置;

      还可以根据方向来用组合写法:

    • border-left : 边框宽度 边框样式 边框颜色;

    用 border 做图形

      边框的交界处是斜线,大师们用这个特性做出了三角形,配合其他属性,可以做出各种图形;

      原理就是:控制四个方向的边框颜色,就可以做出三角形。再控制宽度,就可以做出各种不同的钝角、锐角三角形;

        .triangle {
          border-style: solid;
          border-width: 30px 50px 60px 80px;
          /*我们可以控制各方向边框的宽度,做出各种不同的三角形*/
          border-color: #f00 #0f0 #00f #0ff;
          /*四个方向的颜色自由设置,当设置其他三个方向或两个方向的颜色为transparent(透明色)时,另一方向就成了一个三角形*/
          width: 0;
          /*盒子宽度为0,四个方向的border宽度一致,可以用border做正方形*/
          margin: 100px;
        }

      我比较喜欢根据方向来写三角形,这样容易理解:

      

        .triangle {
          border-left: 10px solid transparent;
          border-right: 10px solid transparent;
          border-bottom: 10px solid #0ff;
          /*我们一般根据方向来写三角形,这样容易记忆;箭头指向的反方向的颜色设置为你想要的,然后箭头方向不要写,另外两个方向的颜色设置为transperent透明*/
        }

    小三角的阴影

      三角形做出来了,但是当我们给元素定义一个 box-shadow,会出现如下情况:

      如果不想要阴影,很好解决,删掉三角形的 box-shadow 就好了;

      而在实际应用中,我们很多情况下是需要阴影的,只是阴影出现在三角形的两条边上,下图给容器设置了阴影;

      

    方法一:

      我们可以在加一个元素,也写成三角形,设置层级比箭头和容器元素都小,并且设置滤镜,位置比箭头稍高,露出边缘部分就可以了;

      当我们把之前的箭头删掉,就是如右图:

      

      完成品:

      

      PS:滤镜也有兼容性问题,建议用谷歌浏览器测试;

      <style type="text/css">
        .note {
          margin: 100px;
          width: 200px;
          height: 80px;
          background: #f60;
          position: relative;
          border-radius: 5px;
          box-shadow: 0 0 10px 0px #000;
          /*水平偏移---垂直偏移---模糊度---扩张半径---颜色*/
        }
    
        .triangle {
          border-left: 10px solid transparent;
          border-right: 10px solid transparent;
          border-bottom: 10px solid #f60;
          /*我们一般根据方向来写三角形,这样容易记忆;箭头指向的反方向的颜色设置为你想要的,然后箭头方向不要写,另外两个方向的颜色设置为transperent透明*/
          position: absolute;
          top: -10px;
          left: 50%;
          margin-left: -10px;
        }
    
        .filter {
          border-left: 10px solid transparent;
          border-right: 10px solid transparent;
          border-bottom: 10px solid #000;
          position: absolute;
          top: -10px;
          left: 50%;
          margin-left: -10px;
          z-index: -1;
          filter: blur(2px);
          /*这又设计到滤镜的知识*/
        }
      </style>
      <div class="wrapper">
        <div class="note">
          <span class="triangle"></span>
          <span class="filter"></span>
        </div>
      </div>

    方法二:

      还是 filter,但是设置 drop-shadow;

      drop-shadow 不支持内阴影,但是支持不规则图形的阴影。

      

      <style type="text/css">
        .note {
          margin: 100px;
          width: 200px;
          height: 80px;
          background: #f60;
          position: relative;
          border-radius: 5px;
          /*box-shadow: 0 0 10px 0px #000;*/
          /*水平偏移---垂直偏移---模糊度---扩张半径---颜色*/
    
          filter: drop-shadow(0 0 6px #000);
          /*看清楚哦,drop-shadow没有扩张半径*/
        }
    
        .triangle {
          border-left: 10px solid transparent;
          border-right: 10px solid transparent;
          border-bottom: 10px solid #f60;
          /*我们一般根据方向来写三角形,这样容易记忆;箭头指向的反方向的颜色设置为你想要的,然后箭头方向不要写,另外两个方向的颜色设置为transperent透明*/
          position: absolute;
          top: -10px;
          left: 50%;
          margin-left: -10px;
        }
      </style>
      <div class="wrapper">
        <div class="note">
          <span class="triangle"></span>
        </div>
      </div>

    小三角的边框

      三角形阴影问题解决方法如上。

      同理,三角形的边框也可以这样写:写个三角形,沉在箭头下边,颜色设置成边框颜色,位置比箭头稍高一些(容器边框宽度值),就可以了;

      接下来我使用 :after 和 :before 写的三角形和边框,同理上面的阴影也可以这样;

      <style type="text/css">
        .note {
          margin: 100px;
          width: 200px;
          height: 80px;
          background: #f0f;
          position: relative;
          border-radius: 5px;
          border: 1px solid #000;
        }
    
        .note:after {
          content: "";
          border-left: 10px solid transparent;
          border-right: 10px solid transparent;
          border-bottom: 10px solid #f0f;
          /*我们一般根据方向来写三角形,这样容易记忆;箭头指向的反方向的颜色设置为你想要的,然后箭头方向不要写,另外两个方向的颜色设置为transperent透明*/
          position: absolute;
          top: -10px;
          left: 50%;
          margin-left: -10px;
        }
    
        .note:before {
          content: "";
          border-left: 10px solid transparent;
          border-right: 10px solid transparent;
          border-bottom: 10px solid #000;
          position: absolute;
          top: -11px;
          /*写个三角形,沉在箭头下边,颜色设置成边框颜色,位置比箭头稍高一些(容器边框宽度值),就可以了*/
          left: 50%;
          margin-left: -10px;
          z-index: -1;
        }
      </style>
      <div class="wrapper">
        <div class="note"></div>
      </div>

    border-radius 圆角

      css3 属性 border-radius,“边框半径”,值可以用 px、em、pt、百分比等。

      border-radius 支持四个角使用不同弧度,方向依次是左上--右上--右下--左下(是从左上开始,顺时针)。

      border-radius 还可以单独对每个角设置:

    • border-top-left-radius
    • border-top-right-radius
    • border-bottom-right-radius  
    • border-bottom-left-radius

      单独设置可以写两个值,第一个值是水平半径,第二个值是垂直半径;如果只有一个值,那么水平和垂直相等。

      <style type="text/css">
        * {
          padding: 0;
          margin: 0;
        }
    
        .test {
          width: 200px;
          height: 80px;
          margin: 100px;
          background: #f0f;
          border-radius: 15px 20px 35px 50px / 10% 25% 1em 50%;
          /*水平-----/-----垂直,中间用“/”隔开*/
          /*左上水平   右上水平   右下水平   左下水平  /  左上垂直   右上垂直   右下垂直   左下垂直*/
          /*这种方法不推荐使用,太乱了,傻傻分不清楚*/
        }
      </style>
      <div class="test"></div>

      当然,这个属性我们用的最多的就是画圆形,把值设成宽度的一半及以上(50%及以上)

    多重边框

    outline 制作多重边框

      有的需求是边框外面还有边框,我们可以用 outline 来写,有一个相关的属性 outline-offset,可以控制描边与边缘的位置关系,可以设置成负值;

      outline 制作多重边框,最多只能两层,而且不能是弧形的;

        .test {
          margin: 100px;
          width: 200px;
          height: 80px;
          border: 10px solid #f0f;
          outline: 15px solid #f90;
          outline-offset: -25px;
        }

    box-shadow 制作多重边框

      box-shadow 可以做很多层(多了会很卡,电脑性能问题),而且配合 border-radius 属性可以做出弧形;

      box-shadow 是不占据空间的,所以无法响应事件,我们可以利用 inset 设置成内阴影,在扩大空间就好了;

        .test {
          margin: 100px;
          width: 200px;
          height: 80px;
          border: 10px solid #f0f;
          border-radius: 25% 30% 50% 29%;
          box-shadow: 0 0 0 10px #0f0, 0 0 0 20px #ff0, 0 0 0 10px #0ff inset;
          /*水平偏移---垂直偏移---扩张半径---模糊度---颜色*/
          /*可以写多个阴影,用逗号隔开*/
          /*inset是内阴影*/
          /*由于box-shadow属性并不占据空间,所以是无法响应事件的,我们可以利用inset内阴影,再用padding扩充空间就好了*/
        }
  • 相关阅读:
    mysql索引
    springboot mybatis 后台框架平台 shiro 权限 集成代码生成器
    java 企业网站源码模版 有前后台 springmvc SSM 生成静态化
    java springMVC SSM 操作日志 4级别联动 文件管理 头像编辑 shiro redis
    activiti工作流的web流程设计器整合视频教程 SSM和独立部署
    .Net Core中的ObjectPool
    文件操作、流相关类梳理
    .Net Core中的配置文件源码解析
    .Net Core中依赖注入服务使用总结
    消息中间件RabbitMQ(一)
  • 原文地址:https://www.cnblogs.com/sspeng/p/6443542.html
Copyright © 2011-2022 走看看