您现在的位置是:网站首页> 编程资料编程资料
CSS 奇思妙想边框动画效果的实现一文教你玩转CSS border(边框)CSS3 按钮边框动画的实现CSS3 实现发光边框特效两款纯CSS3鼠标经过按钮边框动画特效一篇文章带你学习CSS3图片边框css3多种边框悬停按钮填色动画特效css 透明边框background-clip妙用CSS3实现缺角矩形,折角矩形以及缺角边框CSS边框长度控制功能的实现CSS实现半透明边框与多重边框的场景分析
2023-10-17
401人已围观
简介 这篇文章主要介绍了CSS 奇思妙想边框动画效果的实现,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
今天逛博客网站 -- shoptalkshow,看到这样一个界面,非常有意思:

觉得它的风格很独特,尤其是其中一些边框。
嘿嘿,所以来一篇边框特辑,看看运用 CSS,可以在边框上整些什么花样。
border 属性
谈到边框,首先会想到border,我们最常用的莫过于solid,dashed,上图中便出现了dashed。
除了最常见的solid,dashed,CSS border 还支持none,hidden,dotted,double,groove,ridge,inset,outset等样式。除去none,hidden,看看所有原生支持的 border 的样式:

基础的就这些,如果希望实现一个其他样式的边框,或者给边框加上动画,那就需要配合一些其他属性,或是脑洞大开。OK,一起来看看一些额外的有意思的边框。
边框长度变化
先来个比较简单的,实现一个类似这样的边框效果:

这里其实是借用了元素的两个伪元素。两个伪元素分别只设置上、左边框,下、右边框,通过hover时改变两个伪元素的高宽即可。非常好理解。
div { position: relative; border: 1px solid #03A9F3; &::before, &::after { content: ""; position: absolute; width: 20px; height: 20px; } &::before { top: -5px; left: -5px; border-top: 1px solid var(--borderColor); border-left: 1px solid var(--borderColor); } &::after { right: -5px; bottom: -5px; border-bottom: 1px solid var(--borderColor); border-right: 1px solid var(--borderColor); } &:hover::before, &:hover::after { width: calc(100% + 9px); height: calc(100% + 9px); } }CodePen Demo -- width border animation
接下来,会开始加深一些难度。
虚线边框动画
使用dashed关键字,可以方便的创建虚线边框。
div { border: 1px dashed #333; }
当然,我们的目的是让边框能够动起来。使用dashed关键字是没有办法的。但是实现虚线的方式在 CSS 中有很多种,譬如渐变就是一种很好的方式:
div { background: linear-gradient(90deg, #333 50%, transparent 0) repeat-x; background-size: 4px 1px; background-position: 0 0; }看看,使用渐变模拟的虚线如下:

好,渐变支持多重渐变,我们把容器的 4 个边都用渐变表示即可:
div { background: linear-gradient(90deg, #333 50%, transparent 0) repeat-x, linear-gradient(90deg, #333 50%, transparent 0) repeat-x, linear-gradient(0deg, #333 50%, transparent 0) repeat-y, linear-gradient(0deg, #333 50%, transparent 0) repeat-y; background-size: 4px 1px, 4px 1px, 1px 4px, 1px 4px; background-position: 0 0, 0 100%, 0 0, 100% 0; }效果如下:

OK,至此,我们的虚线边框动画其实算是完成了一大半了。虽然border-style: dashed不支持动画,但是渐变支持呀。我们给上述 div 再加上一个hover效果,hover的时候新增一个animation动画,改变元素的bakcground-position即可。
div:hover { animation: linearGradientMove .3s infinite linear; } @keyframes linearGradientMove { 100% { background-position: 4px 0, -4px 100%, 0 -4px, 100% 4px; } }OK,看看效果,hover 上去的时候,边框就能动起来,因为整个动画是首尾相连的,无限循环的动画看起来就像是虚线边框在一直运动,这算是一个小小的障眼法或者小技巧:

这里还有另外一个小技巧,如果我们希望虚线边框动画是从其他边框,过渡到虚线边框,再行进动画。完全由渐变来模拟也是可以的,如果想节省一些代码,使用border会更快一些,譬如这样:
div { border: 1px solid #333; &:hover { border: none; background: linear-gradient(90deg, #333 50%, transparent 0) repeat-x, linear-gradient(90deg, #333 50%, transparent 0) repeat-x, linear-gradient(0deg, #333 50%, transparent 0) repeat-y, linear-gradient(0deg, #333 50%, transparent 0) repeat-y; background-size: 4px 1px, 4px 1px, 1px 4px, 1px 4px; background-position: 0 0, 0 100%, 0 0, 100% 0; } }由于 border 和 background 在盒子模型上位置的差异,视觉上会有一个很明显的错位的感觉:

要想解决这个问题,我们可以把border替换成outline,因为outline可以设置outline-offset。便能完美解决这个问题:
div { outline: 1px solid #333; outline-offset: -1px; &:hover { outline: none; } }最后看看运用到实际按钮上的效果:

上述 Demo 完整代码如下:
CodePen Demo -- dashed border animation
其实由于背景和边框的特殊关系,使用 border 的时候,通过修改background-position也是可以解决的,就是比较绕。关于背景和边框的填充关系,可以看这篇文章:条纹边框的多种实现方式
渐变的其他妙用
利用渐变,不仅仅只是能完成上述的效果。
我们继续深挖渐变,利用渐变实现这样一个背景:
div { position: relative; &::after { content: ''; position: absolute; left: -50%; top: -50%; width: 200%; height: 200%; background-repeat: no-repeat; background-size: 50% 50%, 50% 50%; background-position: 0 0, 100% 0, 100% 100%, 0 100%; background-image: linear-gradient(#399953, #399953), linear-gradient(#fbb300, #fbb300), linear-gradient(#d53e33, #d53e33), linear-gradient(#377af5, #377af5); } }注意,这里运用了元素的伪元素生成的这个图形,并且,宽高都是父元素的200%,超出则overflow: hidden。

接下来,给它加上旋转:
div { animation: rotate 4s linear infinite; } @keyframes rotate { 100% { transform: rotate(1turn); } }看看效果:

最后,再利用一个伪元素,将中间遮罩起来,一个 Nice 的边框动画就出来了:

上述 Demo 完整代码如下,这个效果我最早见于这位作者 --Jesse B
CodePen Demo -- gradient border animation
改变渐变的颜色
掌握了上述的基本技巧之后,我们可以再对渐变的颜色做一些调整,我们将 4 种颜色变成 1 种颜色:
div::after { content: ''; position: absolute; left: -50%; top: -50%; width: 200%; height: 200%; background-color: #fff; background-repeat: no-repeat; background-size: 50% 50%; background-position: 0 0; background-image: linear-gradient(#399953, #399953); }得到这样一个图形:

同样的,让它旋转一起,一个单色追逐的边框动画就出来了:

CodePen Demo -- gradient border animation 2
Wow,很不错的样子。不过如果是单线条,有个很明显的缺陷,就是边框的末尾是一个小三角而不是垂直的,可能有些场景不适用或者 PM 接受不了。

那有没有什么办法能够消除掉这些小三角呢?有的,在下文中我们再介绍一种方法,利用clip-path,消除掉这些小三角。
conic-gradient的妙用
再介绍clip-path之前,先讲讲角向渐变。
上述主要用到了的是线性渐变linear-gradient。我们使用角向渐变conic-gradient其实完全也可以实现一模一样的效果。
我们试着使用conic-gradient也实现一次,这次换一种暗黑风格。核心代码如下:
.conic { position: relative; &::before { content: ''; position: absolute; left: -50%; top: -50%; width: 200%; height: 200%; background: conic-gradient(transparent, rgba(168, 239, 255, 1), transparent 30%); animation: rotate 4s linear infinite; } } @keyframes rotate { 100% { transform: rotate(1turn); } }效果图和示意图如下,旋转一个部分角向渐变的图形,中间的部分使用另外一个伪元素进行遮罩,只漏出线条部分即可:

CodePen Demo -- Rotating border 3
clip-path的妙用
又是老朋友clip-path,有意思的事情它总不会缺席。
clip-path本身是可以进行坐标点的动画的,从一个裁剪形状变换到另外一个裁剪形状。
利用这个特点,我们可以巧妙的实现这样一种 border 跟随效果。伪代码如下:
div { position: relative; &::before { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom: 0; border: 2px solid gold; animation: clippath 3s infinite linear; } } @keyframes clippath { 0%, 100% { clip-path: inset(0 0 95% 0); } 25% { clip-path: inset(0 95% 0 0); } 50% { clip-path: inset(95% 0 0 0); } 75% { clip-path: inset(0 0 0 95%); } }效果图与示意图一起:

CodePen - clip-path border animation
这里,因为会裁剪元素,借用伪元素作为背景进行裁剪并动画即可,使用clip-path的优点了,切割出来的边框不会产生小三角。同时,这种方法,也是支持圆角border-radius的。
如果我们把另外一个伪元素也用上,实际实现一个按钮样式,可以得到这样的效果:
<
相关内容
- CSS 动态高度过渡动画效果的实现CSS实现漂亮的时钟动画效果的实例代码css3动画鼠标放上图片逐渐变大鼠标离开图片逐渐缩小效果CSS 奇思妙想边框动画效果的实现使用CSS3制作版头动画效果CSS3分享图标按钮动画特效代码CSS3通过var()和calc()函数实现动画特效
- 龙纹三国彩蝶秘境资料详细介绍_手机游戏_游戏攻略_
- 金克斯升空闪退黑屏的解决方法_手机游戏_游戏攻略_
- 神雕侠侣关于五倍经验丹的使用分析_手机游戏_游戏攻略_
- 神雕侠侣师门任务攻略详细介绍_手机游戏_游戏攻略_
- 神雕侠侣科举题库答案大全_手机游戏_游戏攻略_
- 天天飞车无限隐身无限combo刷分攻略_手机游戏_游戏攻略_
- 屌丝自传 第2-1关为鲜花上色 图文攻略_手机游戏_游戏攻略_
- 屌丝自传 第2-2关屌丝向前冲 图文攻略_手机游戏_游戏攻略_
- 屌丝自传 第2-3关老虎演杂技 图文攻略_手机游戏_游戏攻略_
