CSS 边框也能动画?小施魔法~

简介: 为边框加上动画效果,往往会让交互显得更加友好。

image.png


边框动画



为边框加上动画效果,往往会让交互显得更加友好。

边框通常设置属性 border/box-shadow/outline,通过它们即可以实现不同的边框效果。


先来看一种基础的边框动画:【码上掘金】

code.juejin.cn/pen/7163822…


主要是设置 outlineoutline-offset 属性,hover 之后赋不同值,实现简单。

再看另一种边款环绕的效果动画:

code.juejin.cn/pen/7163831…

来源:# Fantastic CSS border animation Coco 大佬 tql


接下来我们来拆解一下这个动画效果的实现:


Step1



首先用 conic-gradient 设置矩形的背景为渐变色,并用 border: 0.5rem dotted lime 设置虚线边框。

code.juejin.cn/pen/7163843…

注意,这里还用 background-origin: border-box 调整了背景起始位置;


Step2



将 border 和 padding 进行层次区分,利用 background-clip 属性。

对比设置 3 种 clip 效果:

  1. background-clip:border-box,border-box
  2. background-clip:padding-box,border-box
  3. background-clip:content-box,border-box

code.juejin.cn/pen/7163848…

明显,第 2 种符合预期。


Step3



最后一步添加 border: 0.3rem dotted transparent; 然后加动效控制 conic-gradient;


--angle: 0deg;
conic-gradient(
  from var(--angle),
  #d53e33 0deg 90deg,
  #fbb300 90deg 180deg,
  #377af5 180deg 270deg,
  #399953 270deg 360deg
);
@property --angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
@keyframes rotate {
  to {
    --angle: 360deg;
  }
}

code.juejin.cn/pen/7163851…

如果想去掉中间的渐变内容,只留下边框动画,设置:


/* Create a border */
border: 0.5rem solid transparent;
/* Paint an image in the border */
border-image:
  conic-gradient(
    from var(--angle),
    #d53e33 0deg 90deg,
    #fbb300 90deg 180deg,
    #377af5 180deg 270deg,
    #399953 270deg 360deg
  ) 1
;

code.juejin.cn/pen/7163851…


小结



本篇核心是更加深刻地认识 3 个 CSS 属性:

1. conic-gradientimage.png2. background-originimage.png3. background-clipimage.png


其中,background-origin 和 background-clip 的区别注意区分

二者都是 css3 中引入的两个跟元素背景相关的属性,它们有相同的可选值,即 border、padding、content三种,而且这两个属性表示的都是元素背景与元素边框、补白 (padding) 和内容区域之间的某种关系。


background-origin 定义的是背景位置的起始点;而 background-clip 是对背景(图片和背景色)的切割~


相关文章
|
2月前
|
前端开发
如何设置 CSS 盒子模型的边框样式?
CSS盒子模型的边框样式可以通过`border`属性设置,包括边框宽度、样式和颜色。例如:`border: 2px solid red;` 设置了2像素宽的红色实线边框。也可分别设置四边,如`border-top`、`border-right`等。
|
2月前
|
前端开发 容器
给 CSS 盒子模型添加边框时,需要注意什么?
在给CSS盒子模型添加边框时,需要注意边框的宽度、样式和颜色,以及它如何影响盒子的总尺寸和布局。边框会增加盒子的总宽度和高度,可能需要调整其他属性以保持布局的完整性。
|
2月前
|
机器学习/深度学习 前端开发 JavaScript
|
25天前
纯css3实现的百分比渐变进度条加载动画源码
纯css3实现的百分比渐变进度条加载动画特效源码
53 31
|
2月前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
110 58
|
10天前
|
Web App开发 移动开发 JavaScript
纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码
这是一款基于纯CSS3+SVG实现的节日庆祝五彩纸屑动画效果源码。画面中左下角是一个圆锥形礼炮卡通效果,呈现出节日庆祝时礼花爆破、五彩纸屑纷飞的动画特效。整体动画效果采用纯css3+svg实现,没有引入任何外部图形或js脚本元素。建议使用支持HTML5与css3效果较好的火狐(Firefox)或谷歌(Chrome)等浏览器预览本源码。
27 6
|
20天前
|
前端开发 JavaScript UED
CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画
本文探讨了CSS滚动效果和视差滚动的原理、应用及其对用户体验的影响。从平滑滚动到元素跟随,再到滚动触发动画,这些效果增强了页面的吸引力和互动性。视差滚动通过不同层次元素的差异化移动,增加了页面的深度感和沉浸感。文章还讨论了实现方法、性能优化及案例分析,旨在为设计师和开发者提供实用指导。
45 7
|
25天前
CSS3制作的聚光灯下倒影文字选装动画特效源码
CSS3聚光灯下倒影文字特效是一段基于CSS3实现的聚光灯下带倒影的文字旋转动画效果代码,具有真实的视觉感,同时文字还会在旋转过程中显示出灯光的反射效果,很有意思,欢迎对此段代码感兴趣的朋友前来下载使用。
28 6
|
27天前
|
移动开发 前端开发 JavaScript
除了 CSS3,还有哪些技术可以实现动画效果?
除了 CSS3,还有哪些技术可以实现动画效果?
53 5
|
25天前
纯css3加载loading发光变色动画代码
纯css3加载loading发光变色动画特效代码是一款基于css3 keyframes属性实现的发光变色圆点串联旋转loading加载动画
22 2