这几天工作中遇到一个交互需求,要求实现一个效果,当鼠标移入一个元素的时候,元素出现一个动态的边框,如图:
动态边框
思路看到这个效果,我首先想到的是设置元素的border属性,可惜border不能设置长度,无法实现动效。另外一种实现思路是添加四个p来分别实现上下左右的边框效果,虽然可行,但是要添加四个额外元素,有点儿得不偿失的感觉。难道就没有更好的解决方案了...
就在我绞尽脑汁的时候,灵光乍现,为什么不尝试一下用CSS3多背景来模拟边框呢,背景是可以设置长度的,通过修改背景的长度,就可以实现要求的动效。说干就干,赶快从网上搜索一下CSS3背景的相关知识。
CSS3 BackgroundCSS3对于 background
做了一些修改,最明显的一个就是采用设置多背景,不但添加了4个新属性,并且还对目前的属性进行了调整增强。
在CSS3里面,你可以在一个标签元素里应用多个背景图片。代码类似与CSS2.0版本的写法,但引用图片之间需用“,”逗号隔开。第一个图片是定位在元素最上面的背景,后面的背景图片依次在它下面显示,如下:
background-image: url(image1.jpg), url(image2.jpg), url(image3.jpg);2、新属性:Background Clip
background-clip 顾名思义,背景剪切,用来设置元素的背景(背景图片或颜色)是否延伸到边框下面。
3、新属性: Background Origin此属性需要与 background-position
配合使用。你可以用 background-position
计算定位是从border,padding或content boxes内容区域算起。(类似 background-clip
)
Background Size属性用来设置背景图片的大小。有几个属性值:
5、Background Repeat 调整CSS2里当设置背景的时候,它经常被标签元素截取而显示不全,CSS3介绍了2个新属性来修复此问题。
6、Background Attachment 的调整Background Attachment有了一个新属性值: local
,当标签元素滚动时它才有效(如设置 overflow: scroll;
),当 background-attachment
设置为 scroll
时,背景图片是不随内容滚条滚动的。现在,有了 background-attachment: local
,就可以做到让背景随元素内容滚动而滚动了。
background-blend-mode: normal | multiply | screen | overlay | darken | lighten | color-dodge | color-burn | hard-light | soft-light | difference | exclusion | hue | saturation | color | luminosity;
每种混合效果参见: https://developer.mozilla.org/en-US/docs/Web/CSS/background-blend-mode
CSS3 多背景模拟元素边框我们这里主要使用了 background-img
、 background-size
和 background-position
三个属性。
background-image: [background-image], [background-image], [background-image]; background-position: [background-position], [background-position], [background-position]; background-repeat: [background-repeat], [background-repeat], [background-repeat];
简写形式如下:
background: [background-image] [background-position] [background-repeat], [background-image] [background-position] [background-repeat], [background-image] [background-position] [background-repeat];
现在我们用多背景来模拟一个元素的边框
/*CSS*/.exammple { background: linear-gradient(0, #108b96 2px, #108b96 2px) no-repeat,linear-gradient(-90deg, #108b96 2px, #108b96 2px) no-repeat,linear-gradient(-180deg, #108b96 2px, #108b96 2px) no-repeat,linear-gradient(-270deg, #108b96 2px, #108b96 2px) no-repeat; background-size: 100% 2px, 2px 100%, 100% 2px, 2px 100%; background-position: left top, right top, right bottom, left bottom;}
<p class="exammple"></p>
我们用四个渐变的背景来模拟四个边框(为什么我们要用渐变而不是直接的Color呢?这是由于CSS的多背景只能是 background-image
, background-color
不支持多个值,所有即便是纯色的边框,我们也只能使用渐变)。
初步效果
接下来我们让边框动起来
/*CSS*/.exammple { transition: ease-in .3s; background: linear-gradient(0, #108b96 2px, #108b96 2px) no-repeat,linear-gradient(-90deg, #108b96 2px, #108b96 2px) no-repeat,linear-gradient(-180deg, #108b96 2px, #108b96 2px) no-repeat,linear-gradient(-270deg, #108b96 2px, #108b96 2px) no-repeat; background-size: 0 2px, 2px 0, 0 2px, 2px 0; background-position: left top, right top, right bottom, left bottom;}.exammple:hover { background-size: 100% 2px, 2px 100%, 100% 2px, 2px 100%;}
现在我们已经按要求实现了交互效果。
总结相比border属性,用background的模拟边框存在以下的优势和劣势
优势 | 劣势 |
---|---|
可以控制宽高,渐变色,运动方向等,灵活多变,能实现很多border不能实现的效果,并且不用添加额外的元素 | 不能实现border圆角 |
需要注意的是 background模拟的边框不等同于真正的边框,是不占用边框的宽高的,计算盒子模型时要留心
最后由于CSS3对背景属性的进一步丰富,利用CSS3的多背景可以实现很多以前必须借助js或图片才能实现的效果,比如半透明背景、几何图案背景、条纹背景等,期待和大家一块儿去探索CSS的奥秘。