SVG实现多彩圆环倒计时效果的示例代码


Posted in HTML / CSS onNovember 21, 2017

圆环倒计时我们经常见到,实现的方法也有很多种。但是本文将介绍一种全新的实现方式,使用SVG来实现倒计时功能。

本文主要用到了SVG的stroke-dasharray和stroke-dashoffset特性。下图是倒计时运行效果:

SVG实现多彩圆环倒计时效果的示例代码

SVG倒计时案例

下面说说相关的实现代码。css实现代码如下:

svg {
    transform: rotate(-0.05deg);
}
circle {
    transition: stroke-dasharray .2s;
}
.time-count-x {
    line-height: 1.5;
    position: relative;
}
.time-second {
    position: absolute;
    top: 50%; left: 0; right: 0;
    margin-top: -.75em;
    text-align: center;
    font-size: 100px;
}

相关html代码如下:

<div id="timeCountX" class="time-count-x">
    <svg width="440" height="440" viewBox="0 0 440 440" class="center">
        <defs>
            <linearGradient x1="1" y1="0" x2="0" y2="0" id="gradient1">
                <stop offset="0%" stop-color="#e52c5c"></stop>
                <stop offset="100%" stop-color="#ab5aea"></stop>
            </linearGradient>
           <linearGradient x1="1" y1="0" x2="0" y2="0" id="gradient2">
                <stop offset="0%" stop-color="#4352f3"></stop>
                <stop offset="100%" stop-color="#ab5aea"></stop>
            </linearGradient>
        </defs>
        <g transform="matrix(0,-1,1,0,0,440)">
            <circle cx="220" cy="220" r="170" stroke-width="50" stroke="#f0f1f5" fill="none" stroke-dasharray="1069 1069"></circle>
            <circle cx="220" cy="220" r="170" stroke-width="50" stroke="url('#gradient1')" fill="none" stroke-dasharray="1069 1069"></circle>
            <circle cx="220" cy="220" r="170" stroke-width="50" stroke="url('#gradient2')" fill="none" stroke-dasharray="534.5 1069"></circle>
        </g>
    </svg>
    <span id="timeSecond" class="time-second"></span>
</div>

最后是相关JavaScript代码:

var eleCircles=document.querySelectorAll("#timeCountX circle");
var eleTimeSec=document.getElementById("timeSecond");
var perimeter=Math.PI*2*170;
var circleInit=function(){
    if(eleCircles[1]){
        eleCircles[1].setAttribute("stroke-dasharray","1069 1069")
    }
    if(eleCircles[2]){
        eleCircles[2].setAttribute("stroke-dasharray",perimeter/2+" 1069")
    }
    eleTimeSec.innerHTML=""
};
var timerTimeCount=null;
var fnTimeCount=function(b){
    if(timerTimeCount){
        return
    }
    var b=b||10;
    var a=function(){
        var c=b/10;
        if(eleCircles[1]){
            eleCircles[1].setAttribute("stroke-dasharray",perimeter*c+" 1069")
        }
        if(eleCircles[2]&&b<=5){
            eleCircles[2].setAttribute("stroke-dasharray",perimeter*c+" 1069")
        }
        if(eleTimeSec){
            eleTimeSec.innerHTML=b
        }
        b--;
        if(b<0){
            clearInterval(timerTimeCount);
            timerTimeCount=null;
            alert("时间到!");
            circleInit()
        }
    };
    a();
    timerTimeCount=setInterval(a,1000)
};
fnTimeCount();

整个案例的代码非常少,有喜欢的朋友可以将代码保存到html中,运行一下,体验体验实际效果。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
纯CSS3实现质感细腻丝滑按钮
Mar 09 HTML / CSS
35款精致的 CSS3 和 HTML5 网页模板 推荐
Aug 03 HTML / CSS
使用CSS3中的calc()属性来以算式表达尺寸数值
Jun 06 HTML / CSS
使用CSS3 制作一个material-design 风格登录界面实例
Dec 12 HTML / CSS
利用CSS3伪元素实现逐渐发光的方格边框
May 07 HTML / CSS
css3媒体查询中device-width和width的区别详解
Mar 27 HTML / CSS
HTML5 canvas基本绘图之绘制矩形
Jun 27 HTML / CSS
HTML5使用drawImage()方法绘制图像
Jun 23 HTML / CSS
详解如何解决H5开发使用wx.hideMenuItems无效果不生效
Jan 20 HTML / CSS
CSS3实现的文字弹出特效
Apr 16 HTML / CSS
css常用字体属性与背景属性介绍
Feb 28 HTML / CSS
CSS元素定位之通过元素的标签或者元素的id、class属性定位详解
Sep 23 HTML / CSS
HTML5响应式(自适应)网页设计的实现
Nov 17 #HTML / CSS
localStorage、sessionStorage使用总结
Nov 17 #HTML / CSS
html5实现移动端适配完美写法
Nov 16 #HTML / CSS
关于h5中的fetch方法解读(小结)
Nov 15 #HTML / CSS
canvas 实现 github404动态效果的示例代码
Nov 15 #HTML / CSS
手机端用rem+scss做适配的详解
Nov 15 #HTML / CSS
基于HTML5的WebGL经典3D虚拟机房漫游动画
Nov 15 #HTML / CSS
You might like
PHP语言中global和$GLOBALS[]的分析 之二
2012/02/02 PHP
Ajax 数据请求的简单分析
2011/04/05 Javascript
JavaScript中的onerror事件概述及使用
2013/04/01 Javascript
Javascript中this的用法详解
2014/09/22 Javascript
JS 新增Cookie 取cookie值 删除cookie 举例详解
2014/10/10 Javascript
20个实用的JavaScript技巧分享
2014/11/28 Javascript
jQueryUI DatePicker 添加时分秒
2016/06/04 Javascript
JS本地刷新返回上一页代码
2016/07/25 Javascript
微信小程序 chooseImage选择图片或者拍照
2017/04/07 Javascript
基于匀速运动的实例讲解(侧边栏,淡入淡出)
2017/10/17 Javascript
node.js 用socket实现聊天的示例代码
2017/10/17 Javascript
Vue2 监听属性改变watch的实例代码
2018/08/27 Javascript
vuejs数据超出单行显示更多,点击展开剩余数据实例
2019/05/05 Javascript
关于AOP在JS中的实现与应用详解
2019/05/06 Javascript
小程序根据手机机型设置自定义底部导航距离
2019/06/04 Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
2020/04/27 Javascript
[34:10]Secret vs VG 2019国际邀请赛淘汰赛 败者组 BO3 第二场 8.24
2019/09/10 DOTA
Python列出一个文件夹及其子目录的所有文件
2016/06/30 Python
利用python实现简易版的贪吃蛇游戏(面向python小白)
2018/12/30 Python
对Python捕获控制台输出流的方法详解
2019/01/07 Python
Python集合基本概念与相关操作实例分析
2019/10/30 Python
Pycharm打开已有项目配置python环境的方法
2020/07/03 Python
使用matplotlib的pyplot模块绘图的实现示例
2020/07/12 Python
python实现每天自动签到领积分的示例代码
2020/08/18 Python
html5声频audio和视频video等新特性详细说明
2012/12/26 HTML / CSS
WINDOWS域的具体实现方式是什么
2014/02/20 面试题
中学教师教育感言
2014/02/21 职场文书
小学生手册家长评语
2014/04/16 职场文书
医学生求职自荐书
2014/06/12 职场文书
推普周国旗下讲话稿
2014/09/21 职场文书
乡镇领导班子批评与自我批评材料
2014/09/23 职场文书
党的群众路线教育实践活动心得体会(医院)
2014/11/03 职场文书
2014年体检中心工作总结
2014/12/23 职场文书
2015年收银员个人工作总结
2015/04/01 职场文书
实习员工转正的评语汇总,以备不时之需
2019/12/17 职场文书
Mysql 用户权限管理实现
2021/05/25 MySQL