纯css实现动态边框的示例代码

2020-05-16 07:20:10易采站长站整理

背景

这几天工作中遇到一个交互需求,要求实现一个效果,当鼠标移入一个元素的时候,元素出现一个动态的边框,如图:

 

动态边框

思路

看到这个效果,我首先想到的是设置元素的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内容区域位置算起;