css3 模拟圆角outline

  今天网上看到张鑫旭大神的一篇模拟圆角outline的文章,觉得很强大,很神奇,很流弊,所以赶紧记录下来,供大家分享,学习!

  outline有个特性就是它不会占据空间,这是个很强大的属性,但是一般的outline都是方形的,那怎么才能实现绚丽的圆角outline效果了?我们都知道css3中有border-radius属性可以设置圆角,但是如果配合border和border-radius是会增加盒子的大小的!

这时我们就需要用到box-shadow和border-radius组合来模拟圆角的outline效果了!废话不多说,先上代码:

  

 1 <!DOCTYPE html>
 2     <html>
 3      <head>
 4       <style type="text/css">
 5           div{margin:0;padding:0;}
 6          div.outlineRadius{width:250px;height:250px;line-height:250px;text-align:center;}    
 7           .outlineRadius{border-radius:1px;box-shadow:0 0 0 25px #00438a;}
 8      </style>
 9      </head>
10      <body>
11      <div class="outlineRadius">圆角的outline效果盒子</div> 
12      </body>
13 </html>

运行效果如下:

  大家可以在chrome的调试工具中看此盒子的大小还是height:250px;

  为什么能达到这效果?因为盒子有1px的圆角,而盒子的阴影水平便宜为0,垂直便宜为0,阴影模糊距离为0,想象下这盒子其实看起来是没有阴影的,因为盒子的阴影刚好是盒子的大小,然而第四个参数根据w3c官方解释为阴影的尺寸,所以第四个

参数扩展了盒子的阴影,又因为盒子有1px的圆角所以就达到了模拟圆角outline的效果啦!是不是很棒啊!

原文地址:https://www.cnblogs.com/QingChengFE/p/4484429.html