利用SVG和CSS3实现炫酷的边框动画

这篇文章主要介绍了利用svgcss3来实现一个炫酷的边框动画,不使用javascript使得编写过程轻松了不少,需要的朋友可以参考下

今天我们来探索一下Carl Philipe Brenner的网站上一个微妙而有趣的动画效果。当鼠标经过网格元素时,会有一个微妙的动画发生——网格元素变得透明,每条边有个顺时针的动画,创造了非常好的效果。这种效果是通过JS给span标签的宽或者高做了动画。我们待会会用SVG和CSS渐变来完成。注意,这个技术还是实验性的。

首先,让我们来看看基本的概念,然后我们会朝着这个方向努力。

请注意,我们将在SVG上使用CSS过渡,可能无法得到所有浏览器的支持。

乍眼一看可能不明白这个效果是怎么完成的。我们先仔细看看上面的边就会发现,白色的边的宽度不断从右边往左边延伸,而一条稍微延时的边紧跟着一起移动。每条边都有这样的做法。看起来就像上面的边经过拐角移动到了左边,并以此类推。

立即学习“前端免费学习笔记(深入)”;

不用SVG也能完成这样的效果,甚至只用伪元素。但是我们想探索一下怎样用CSS而不是JavaScript来控制SVG。

现在,来思考一下要怎么创建出这样的效果。我们可以改变矩形的troke-dashoffset或者直接画线。我们尝试不用JavaScript的解决方案。我们发现,CSS过渡stroke-dashoffset 和 stroke-dasharray的值会触发很多BUG。所以我们要尝试不同的解决方案,利用线条和它们的动画,这在CSS里很容易理解和实现。这也给我们更多机会去探索不同的动画效果。

我们将要使用的线的特别之处是,它们在这个动画里将有三种状态。它们是方盒边长的三倍,其中中间一截是与边等长的间隙。我们将通过设置stroke-dashoffset的值来实现与方盒的边等长。现在,这个动画实现的关键在于线的位置转换:
2015722165434429.gif (600×369)

SVG与方盒大小一致,就不会看到超出虚线的部分。

我们先完成第一条线:

这个p长宽20px,和SVG一样。把SVG位置设为absolute,线宽度为10,stroke-dasharray为200。

p {       width: 200px;       height: 200px;       position: relative;       overflow: hidden;       background: #ddd;   }     svg {       position: absolute;       top: 0;       left: 0;   }     svg line {       stroke-width: 10;       stroke: #000;       fill: none;       stroke-dasharray: 200;       -webkit-transition: -webkit-transform .6s ease-out;       transition: transform .6s ease-out;   }     p:hover svg line {       -webkit-transform: translateX(-400px);       transform: translateX(-400px);   }

当数鼠标悬浮在p上时,线也有一个过渡。我们要把线移动到它的三分之二处,所以要在x轴上移动到-400px处,你可以看看这个效果。因为translation不能在这里用百分比做单位,所以用px。

接着添加其余三条线,gif效果:
2015722165612818.gif (600×369)

我们需要实现以下效果:线的第一部分移出方盒后,旁边的线的最后一部分移动进来,,这将传进直线在转角处转弯的假象,

来看看坐标系的定义:
2015722165651126.png (600×442)

左边的线的坐标是(0,200) 到 (0,-400),底部的是(200,200) 到 (-400,200),右边的是right one (200,0) 到 (200,600):

给每条线加上不同的hover效果:

p:hover svg line.top {     -webkit-transform: translateX(-400px);     transform: translateX(-400px);   }     p:hover svg line.bottombottom {     -webkit-transform: translateX(400px);     transform: translateX(400px);   }     p:hover svg line.left {     -webkit-transform: translateY(400px);     transform: translateY(400px);   }     p:hover svg line.rightright {     -webkit-transform: translateY(-400px);     transform: translateY(-400px);   }

看看现在的效果。

现在方盒大小改为300 x 460,再给它添加一些内容:

D

2012 Broccoli, Asparagus, Curry

为了实现Carl Philipe Brenner的网站上的效果,我们还要添加颜色过渡效果、盒子阴影等:

.box {       width: 300px;       height: 460px;       position: relative;       background: rgba(255,255,255,1);       display: inline-block;       margin: 0 10px;       cursor: pointer;       color: #2c3e50;       box-shadow: inset 0 0 0 3px #2c3e50;       -webkit-transition: background 0.4s 0.5s;       transition: background 0.4s 0.5s;   }     .box:hover {       background: rgba(255,255,255,0);       -webkit-transition-delay: 0s;       transition-delay: 0s;   }

给文字加上样式:

.box h3 {       font-family: "Ruthie", cursive;       font-size: 180px;       line-height: 370px;       margin: 0;       font-weight: 400;       width: 100%;   }     .box span {       display: block;       font-weight: 400;       text-transform: uppercase;       letter-spacing: 1px;       font-size: 13px;       padding: 5px;   }     .box h3,   .box span {       -webkit-transition: color 0.4s 0.5s;       transition: color 0.4s 0.5s;   }     .box:hover h3,   .box:hover span {       color: #fff;       -webkit-transition-delay: 0s;       transition-delay: 0s;   }

给SVG和线条添加样式:

.box svg {       position: absolute;       top: 0;       left: 0;   }     .box svg line {       stroke-width: 3;       stroke: #ecf0f1;       fill: none;       -webkit-transition: all .8s ease-in-out;       transition: all .8s ease-in-out;   }

给线的过渡加上延时:

.box:hover svg line {       -webkit-transition-delay: 0.1s;       transition-delay: 0.1s;   }

之前我们定义的stroke-dasharray只有一个值,但是现在要因尺寸变化而修改

.box svg line.top,   .box svg line.bottombottom {       stroke-dasharray: 330 240;    }     .box svg line.left,   .box svg line.rightright {       stroke-dasharray: 490 400;   }

如果你尝试这些值,你就能看到这些线条不同的显示效果。

最后,我们要个hover过渡设置相应的值。因为现在元素是300px宽,所以水平线条改为900px,竖线同理改变:

.box:hover svg line.top {       -webkit-transform: translateX(-600px);       transform: translateX(-600px);   }     .box:hover svg line.bottombottom {       -webkit-transform: translateX(600px);       transform: translateX(600px);   }     .box:hover svg line.left {       -webkit-transform: translateY(920px);       transform: translateY(920px);   }     .box:hover svg line.rightright {       -webkit-transform: translateY(-920px);       transform: translateY(-920px);   }

大功告成。希望能通过这些效果激发你的创意,实现更多的效果~

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

CSS实现文字环绕图片的效果

关于HTML5和CSS3实现时钟的效果

利用CSS3制作的鼠标悬停时边框旋转

以上就是利用SVG和CSS3实现炫酷的边框动画的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1610623.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
利用CSS3实现了八组超炫酷鼠标滑过图片动画
上一篇 2025年12月24日 01:35:34
CSS使用盒模型实例
下一篇 2025年12月24日 01:35:54

相关推荐

  • 利用css3仿造window7的开始菜单

    相当逼真,css3果然强悍。要留意的点依旧是哪几项,难点在于细节的微调,尤其是渐变背景的制作,css3中非常灵活,下次有机会,发篇css3渐变背景的详细教程。   相当逼真,css3果然强悍。友情提示:请勿在IE下浏览。来看下原作者的设计草图: 简明创建过程  第一步 :创建如下菜单结构 @@##@…

    2026年5月10日
    000
  • p5.js图像像素化与阈值处理:loadPixels()函数深度解析与性能优化

    本教程深入探讨p5.js中`loadpixels()`函数在图像像素化与阈值处理中的应用。我们将重点讲解如何优化`loadpixels()`的调用时机以提升性能,正确计算图像亮度,并构建清晰有效的条件阈值逻辑。文章还涵盖了避免变量命名冲突、选择合适的绘图函数等关键实践,旨在帮助开发者高效、准确地实现…

    2026年5月10日
    000
  • 怎么安装html5_HTML5开发环境安装与配置详细步骤

    答案是配置HTML5开发环境需三步:1. 安装VS Code等编辑器并配置插件;2. 使用Chrome或Firefox测试页面;3. 可选搭建本地服务器,如Live Server或http-server;最后创建index.html文件验证环境。 安装HTML5开发环境其实并不复杂,因为HTML5本…

    2026年5月10日
    000
  • 使用CSS Grid实现不规则列布局:告别传统表格的限制

    本教程详细阐述如何利用css grid实现复杂的、不规则的列布局,尤其适用于那些传统html表格难以实现的块状结构。文章将通过具体的css属性和html结构示例,指导读者如何定义网格、控制子项的跨度与位置,以及优化自动布局流程,从而高效构建灵活且响应式的页面布局。 1. 传统表格的局限与CSS Gr…

    2026年5月10日
    000
  • SVG动态图形:实现路径与圆形元素的振动效果

    本教程详细介绍了如何利用SVG的SMIL动画功能,为线条和圆形元素创建生动的振动或摆动效果。我们将学习如何将直线转换为可动画的路径,并同步动画圆形元素的位置,以及如何将图像嵌入到动态圆形中,为您的SVG图形注入生命力,使其不再是静态的图像。 在svg中,为图形元素添加动态效果是提升用户体验和视觉吸引…

    2026年5月10日
    000
  • 前端构建优化:利用常量折叠提升应用性能

    本文深入探讨了一种在构建阶段执行部分源代码以进行优化的技术——常量折叠(Constant Folding)。通过在编译时预计算表达式并替换为最终结果,该技术显著减少了运行时开销,提升了应用性能。文章将详细解释其工作原理、优势,并探讨其在现代前端构建工具中的应用与配置,旨在帮助开发者实现更高效的代码优…

    2026年5月10日
    000
  • border-radius属性如何使用

    border-radius属性用于创建圆角,其使用语法是“border-radius: 1-4 length|%;”,border-radius是一个最多可指定四个“border -*- radius”属性的复合属性。 本文操作环境:Windows7系统、Dell G3电脑、HTML5&&a…

    2026年5月10日
    000
  • 详解img[src=””] img无路径情况下,灰色边框去除解决方法

    img[src=””]  img标签无路径情况下,灰色边框去除解决方案 1.Js解决办法 @@##@@ function whenError(a){ a.onerror=null; a.src=’path_default.jpg’; console.log(‘图片出错的时候调…

    用户投稿 2026年5月10日
    000
  • 使用 CSS 创建箭头轮廓的技巧

    本文介绍了如何使用 CSS 为箭头形状创建轮廓效果。传统的 `outline` 属性会围绕整个元素盒子生成轮廓,而本文提供了一种使用 `box-shadow` 属性来模拟箭头轮廓的解决方案,并添加伪元素以完善轮廓的视觉效果,从而实现更精确的轮廓控制。 在 CSS 中,使用 outline 属性可以为…

    2026年5月10日
    000
  • html5插入按钮元素_button与input按钮创建【教程】

    HTML5提供button和input[type=”button”]两种按钮实现方式:前者语义强、支持嵌套内容与无障碍,后者兼容性好但仅通过value设文本;二者均支持disabled禁用及JavaScript交互,并需注意CSS样式与可访问性优化。 如果您希望在网页中添加可…

    2026年5月10日
    200
  • HTML5怎么制作天气应用_HTML5天气组件开发实战

    使用HTML5、CSS3和JavaScript结合OpenWeatherMap API可快速开发响应式天气应用。2. 页面结构包含输入框、按钮和结果显示区域。3. 通过fetch调用API获取实时天气数据,支持中文和摄氏度单位。4. 数据渲染包括城市名、温度、图标、湿度和风速,并用CSS美化界面。5…

    2026年5月10日
    000
  • 关于CSS3字体属性整理分析

     字体属性: Font-family: {font-family: name}           {font-family: cursive| fantasy | monospace | serif | sans-serif} Font-size: {font-size: 数值 | inherit…

    用户投稿 2026年5月10日
    000
  • JavaScript实现可折叠图片显示/隐藏功能教程

    JavaScript实现可折叠图片显示/隐藏功能教程JavaScript实现可折叠图片显示/隐藏功能教程JavaScript实现可折叠图片显示/隐藏功能教程JavaScript实现可折叠图片显示/隐藏功能教程

    本教程详细介绍了如何使用JavaScript和HTML创建一个可折叠的图片显示/隐藏功能。通过引入一个状态变量来管理图片当前是展开还是折叠,结合按钮点击事件动态切换图片的可见性及按钮文本,实现用户友好的交互式内容展示,适用于在网页中按需显示或隐藏图片资源。 1. 功能概述与核心思路 在网页开发中,有…

    2026年5月10日 用户投稿
    000
  • 使用Flexbox实现内容居中布局:从页脚固定到内容对齐

    本文深入探讨了如何利用CSS Flexbox实现网页内容的精确居中对齐,尤其是在包含固定页脚的复杂布局中。我们将通过分析一个常见的布局问题,逐步讲解如何配置Flex容器及其子项的属性,如`display: flex`、`flex-direction`、`justify-content`和`text-…

    2026年5月10日
    000
  • 学习html5编程路径_从基础到项目实战路线【方法】

    需遵循由浅入深的学习路径:一、分阶段夯实HTML/CSS/JS基础与HTML5新API;二、通过待办列表、Canvas画板等微型项目整合技能;三、参与开源或复刻经典界面提升工程素养;四、用Vite等工具实践构建流程;五、打造可展示的全栈作品集。 如果您希望系统性地掌握HTML5编程技能,并最终能够独…

    2026年5月10日
    600
  • 使用 D3.js 和 Webpack 构建 SVG 地图时渲染失败的解决方案

    本文档旨在解决在使用 D3.js 结合 Webpack 构建包含自定义地图投影的网站时,SVG 地图无法渲染的问题。通过分析问题代码和解决方案,我们将深入探讨 D3.js 中元素选择和动态创建 SVG 元素的关键点,并提供一种有效的解决方案,帮助开发者避免类似错误,成功渲染 SVG 地图。 问题分析…

    2026年5月10日
    000
  • HTML背景图片多层叠加怎么实现_HTML背景图片多层叠加CSS技巧

    多层背景通过CSS实现,使用background属性并用逗号分隔各层,顺序从上到下堆叠,配合background-size、position等子属性精确控制每层显示效果,提升视觉层次。 在网页设计中,实现多层背景图片叠加可以增强视觉层次感和创意表现。通过CSS的background属性,我们可以轻松…

    2026年5月10日
    000
  • 如何在多个文件输入框中实现独立图片预览功能

    本教程详细阐述了如何在网页中实现多个文件输入框(`input type=”file”`)的独立图片预览功能。通过识别并解决常见错误,如重复id导致的元素选择不当,我们将演示如何利用dom遍历和事件委托,为每个上传区域动态绑定预览逻辑,确保用户上传的每张图片都能在其对应的位置正…

    2026年5月10日
    000
  • css权重是什么?css权重的介绍

    本篇文章给大家带来的内容是关于css权重是什么?css权重的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 1、什么是css权重?css6大基础选择器 css权重指的是css6大基础选择符的优先级,优先级高的css样式会覆盖优先级底的css样式,优先级越高说明权重越高,反之亦然…

    2026年5月10日
    100
  • 如何使用CSS的Grid布局实现小松鼠邮票的效果(附源码)

    本篇文章给大家带来的内容是关于如何使用css的grid布局实现小松鼠邮票的效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 效果预览 源代码下载 每日前端实战系列的全部源代码请从 github 下载: https://github.com/comehope/front-…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信