zoukankan      html  css  js  c++  java
  • css outline实践研究

    outline具有和border很相似的属性,但多少又有些区别,就是因为这些区别才让它闪闪发光,先目睹一下。

    <style>
      div{
        100px;
        height:100px;
        background-color:red;
        outline:10px solid #ccc;
      }
    </style>
    <div></div>
    

    好像和“border”没啥区别,那么看下面这张图

    它的宽和高还是100px,并没有增加边框的宽度。

    也就是说:outline不占据布局空间,不会影响元素的尺寸,如果是这样的话,那可是可以解决很多问题啊,比如一个图片默认没有边框,hover的时候有一个1px的边框,那么如果不做处理盒子会抖动一下,解决这个问题可能就是默认给一个白色的边框或者给个padding,但是有了outline就好办了,直接写就好了。

    来研究一下它是不是真的不据布局空间。

    它把下面的文字盖住了,但并没有改变元素的布局方式,这足够说明它确实是不占位置的。

    outline还有一个强大的属性叫outline-offset可以设置边框的偏移量。

    <style>
      div{
        margin:100px;
        100px;
        outline:1px solid red;
        outline-offset:10px;
      }
    </style>
    <div>追梦子</div>
    

    值也可以是负的。

    利用outline制作炫酷效果

    代码如下:

    <style>
      div{
        margin:100px;
        display:inline-block;
        position:relative;
      }
      div::after{
        content:'';
        position:absolute;
        left:-50px;
        top:-100px;
        100%;
        height:100%;
        outline:0px solid #fff;
        outline-offset:15px;
        transition:all .5s;
      }
      div:hover::after{
        left:0px;
        top:0px;
        outline:1px solid currentColor;
        outline-offset:3px;
      }
    </style>
    <div>追梦子</div>
    
    可以同时设置“border”和“outline”

    <style>
      div{
        margin:100px;
        100px;
        border:1px  solid red;
        outline:1px solid red;
        outline-offset:10px;
      }
    </style>
    <div>追梦子</div>
    

    不过值得注意的是,outline不会继承border-radius。

    outline结合offset制作十字架

    <style>
      div{
        margin: 0 auto;
         100px;
        height: 100px;
        background-color: red;
        outline: 34px dotted #fff;
        outline-offset: -33px;
      }
    </style>
    <div></div>
    

    <style>
      div{
        margin: 0 auto;
         100px;
        height: 100px;
        background-color: red;
        position:relative;
      }
      div::after{
        content:'';
        100%;
        height:100%;
        position:absolute;
        left:0;
        top:0;
        outline: 31px outset #fff;
        outline-offset: -80px;
      }
    </style>
    <div></div>
    
  • 相关阅读:
    Spring Boot中使用logback日志框架
    Java日志框架-logback配置文件参考(转)
    Java日志框架-logback配置文件多环境日志配置(开发、测试、生产)(原始解决方法)
    MySQL取每组的前N条记录
    跟大佬一起读源码:CurrentHashMap的扩容机制
    源码速读及点睛:HashMap
    求两个Linux文本文件的交集、差集、并集
    哪个先执行:@PostConstruct和@Bean的initMethod?
    Android Studio3.0 Error:Execution failed for task ':app:javaPreCompileDebug' 错误
    Android原生项目集成React Native
  • 原文地址:https://www.cnblogs.com/pssp/p/5906676.html
Copyright © 2011-2022 走看看