背景
这几天工作中遇到一个交互需求,要求实现一个效果,当鼠标移入一个元素的时候,元素出现一个动态的边框,如图:
动态边框
思路
看到这个效果,我首先想到的是设置元素的border属性,可惜border不能设置长度,无法实现动效。另外一种实现思路是添加四个div来分别实现上下左右的边框效果,虽然可行,但是要添加四个额外元素,有点儿得不偿失的感觉。难道就没有更好的解决方案了…
就在我绞尽脑汁的时候,灵光乍现,为什么不尝试一下用CSS3多背景来模拟边框呢,背景是可以设置长度的,通过修改背景的长度,就可以实现要求的动效。说干就干,赶快从网上搜索一下CSS3背景的相关知识。
CSS3 Background
CSS3对于background 做了一些修改,最明显的一个就是采用设置多背景,不但添加了4个新属性,并且还对目前的属性进行了调整增强。
1、 多个背景图片
在CSS3里面,你可以在一个标签元素里应用多个背景图片。代码类似与CSS2.0版本的写法,但引用图片之间需用“,”逗号隔开。第一个图片是定位在元素最上面的背景,后面的背景图片依次在它下面显示,如下:
background-image: url(image1.jpg), url(image2.jpg), url(image3.jpg);
2、新属性:Background Clip
background-clip 顾名思义,背景剪切,用来设置元素的背景(背景图片或颜色)是否延伸到边框下面。
background-clip: border-box; 背景延伸至边框外沿(但是在边框下层)
background-clip: padding-box; 背景延伸至内边距(padding)外沿。不会绘制到边框处
background-clip: content-box; 背景被裁剪至内容区(content box)外沿
background-clip: text; 背景被裁剪成文字的前景色(实验属性,需要加浏览器前缀)
3、新属性: Background Origin
此属性需要与background-position 配合使用。你可以用 background-position 计算定位是从border,padding或content boxes内容区域算起。(类似 background-clip )
注意:当使用 background-attachment 为fixed时,该属性将被忽略不起作用。background-origin:border-box; 从border边框位置算起
background-origin:padding-box; 从padding位置算起
background-origin:content-box; 从content-box内容区域位置算起;