css outline实践研究

本文详细介绍了CSS中outline属性的特点及应用技巧,包括其与border的区别、如何利用outline-offset实现特殊效果,以及如何结合其他属性创造视觉冲击力强的设计。

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

857662-20160925191818458-1346196749.png

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

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

857662-20160925191849007-2001309035.png

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

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

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

857662-20160925192557350-1976005213.gif

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

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

857662-20160925195545319-1109384045.png

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

值也可以是负的。

利用outline制作炫酷效果

857662-20160925203842501-1074688900.gif

代码如下:

<style>
  div{
    margin:100px;
    display:inline-block;
    position:relative;
  }
  div::after{
    content:'';
    position:absolute;
    left:-50px;
    top:-100px;
    width: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”

857662-20160925195720435-1821100577.png

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

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

outline结合offset制作十字架

857662-20160925201456822-1649744878.gif

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

857662-20160925203504064-1009842415.png

<style>
  div{
    margin: 0 auto;
    width: 100px;
    height: 100px;
    background-color: red;
    position:relative;
  }
  div::after{
    content:'';
    width:100%;
    height:100%;
    position:absolute;
    left:0;
    top:0;
    outline: 31px outset #fff;
    outline-offset: -80px;
  }
</style>
<div></div>
## 01、数据介绍 数据整理全国30个省份制造业细分行业产值,能够反映一定时期内细分行业工业生产总规模和总水平的指标,是计算工业生产发展速度和主要比例关系、计算工业产品销售率等其他经济指标的基础。先进制造业数据可用于两业融合测算。 数据名称:全国30省-制造业细分行业产值/先进制造业细分行业产值数据 数据年份:2001-2022年 ## 02、数据指标 农副食品加工业;食品制造业;饮料制造业;烟草制造业;纺织业;纺织服装鞋帽制造业;皮革、毛皮、羽毛(绒)极其制品业;木材加工及木、竹、藤、棕、草制品业;家具制造业;造纸及纸制品业;印刷业和记录媒介的复制;文教体育用品制造业;石油加工、炼焦及核燃料加工业化;学原料及化学制品制造业;医药制造业;化学纤维制造业;橡胶和塑料制品制品业;非金属矿物制品业;黑色金属冶炼及压延加工业;有色金属冶炼及压延加工业;金属制品业;通用设备制造业;专用设备制造业;汽车制造业;其他运输设备制造业;电气机械及器材制造业;通信设备计算机及其他电子设备制造业;仪器仪表及文化、办公用机械制造业;其他制造业;废弃资源和废旧材料回收加工业;制造业总产值 印刷业和记录媒介的复制;石油加工、炼焦及核燃料加工业;化学原料及化学制品制造业;医药制造业;橡胶和塑料制品制品业;非金属矿物制品业;黑色金属冶炼及压延加工业;有色金属冶炼及压延加工业;金属制品业;通用设备制造业;专用设备制造业;汽车制造业;其他运输设备制造业;电气机械及器材制造业;通信设备计算机及其他电子设备制造业;仪器仪表及文化、办公用机械制造业;废弃资源和废旧材料回收加工业
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值