0

0

HTML5 SVG带圆形进度条动画的提交按钮特效

PHP中文网

PHP中文网

发布时间:2016-05-17 09:07:33

|

3144人浏览过

|

来源于php中文网

原创

简要教程

这是一款非常实用的HTML5 SVG带圆形进度条动画的提交按钮特效。该提交按钮在被点击之后,按钮变形为一个圆形的进度条,当进度条运行一周之后,可以设置提交成功和提交失败的两种按钮状态。

 制作方法

 HTML结构

制作这个提交按钮特效的HTML结构需要一个包裹容器,里面有一个提交按钮和三个svg>元素。

CSS样式

首先提交按钮容器需要设置为inline-block样式。

.progress-button {
  position: relative;
  display: inline-block;
  text-align: center;
}

然后在为提交按钮提供一些基本样式,并设置过渡动画效果。

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

.progress-button button {
  display: block;
  margin: 0 auto;
  padding: 0;
  width: 250px;
  height: 70px;
  border: 2px solid #1ECD97;
  border-radius: 40px;
  background: transparent;
  color: #1ECD97;
  letter-spacing: 1px;
  font-size: 18px;
  font-family: 'Montserrat', sans-serif;
  -webkit-transition: background-color 0.3s, 
                      color 0.3s, width 0.3s, 
                      border-width 0.3s, 
                      border-color 0.3s;
  transition: background-color 0.3s, 
              color 0.3s, width 0.3s, 
              border-width 0.3s, 
              border-color 0.3s;
}

在鼠标滑过提交按钮的时候,修改按钮的背景颜色和文字颜色。

.progress-button button:hover {
  background-color: #1ECD97;
  color: #fff;
}

所有的SVG元素都采用绝对定位方式来居中对齐,并且不允许有任何的pointer-events。

.progress-button svg {
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  pointer-events: none;
}

SVG的路径没有任何的填充色,只有描边。开始的时候它们是被隐藏起来的,透明度被设置为0。

SVG单选多选表单按钮动画特效
SVG单选多选表单按钮动画特效

SVG单选多选表单按钮动画特效是一款基于gsap svg制作的圆点单选开关按钮,勾选复选按钮,提交按钮ui奶油动画效果。

下载
.progress-button svg path {
  opacity: 0;
  fill: none;
}

圆形进度条通过设置描边为5个单位来创建。

.progress-button svg.progress-circle path {
  stroke: #1ECD97;
  stroke-width: 5;
}

当开始loading线程的时候,按钮会变形为圆形,和圆形进度条相同的大小。

.loading.progress-button button {
  width: 70px; /* 制作一个圆形 */
  border-width: 5px;
  border-color: #ddd;
  background-color: transparent;
  color: #fff;
}

变为圆形后,调教按钮上的文字要快速隐藏起来。

.loading.progress-button span {
  -webkit-transition: opacity 0.15s;
  transition: opacity 0.15s;
}
.loading.progress-button span,
.success.progress-button span,
.error.progress-button span {
  opacity: 0; /* keep it hidden in all states */
}

 JAVASCRIPT

在javascript代码中,button是HTML元素,progressEl是SVG元素,它是代表圆形的进度条。successEl和errorEl分别代表提交成功和失败的标记,也是SVG元素。js代码中通过UIProgressButton()方法来初始化这个提交按钮特效。

function UIProgressButton( el, options ) {
  this.el = el;
  this.options = extend( {}, this.options );
  extend( this.options, options );
  this._init();
}
 
UIProgressButton.prototype._init = function() {
  this.button = this.el.querySelector( 'button' );
  this.progressEl = new SVGEl( this.el.querySelector( 'svg.progress-circle' ) );
  this.successEl = new SVGEl( this.el.querySelector( 'svg.checkmark' ) );
  this.errorEl = new SVGEl( this.el.querySelector( 'svg.cross' ) );
  // init events
  this._initEvents();
  // enable button
  this._enable();
}

其它js代码请参考下载文件。

以上就是HTML5 SVG带圆形进度条动画的提交按钮特效的内容,更多相关内容请关注PHP中文网(www.php.cn)!

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

10

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

29

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

21

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

13

2026.01.22

PHP特殊符号教程合集
PHP特殊符号教程合集

本专题整合了PHP特殊符号相关处理方法,阅读专题下面的文章了解更多详细内容。

11

2026.01.22

PHP探针相关教程合集
PHP探针相关教程合集

本专题整合了PHP探针相关教程,阅读专题下面的文章了解更多详细内容。

8

2026.01.22

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

55

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.8万人学习

HTML+CSS基础与实战
HTML+CSS基础与实战

共132课时 | 9.7万人学习

前端开发(基础+实战项目合集)
前端开发(基础+实战项目合集)

共60课时 | 3.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号