X  
登录

暂时未开放注册

忘记密码?
登陆
X  
本站已关闭注册功能
统计
  • 建站日期:2022-03-19
  • 文章总数:403 篇
  • 评论总数:239 条
  • 分类总数:22 个
  • 最后更新:12月5日
文章 程序编程

给网站添加一个活动倒计时效果 线报活动结束提示效果

安生
首页 程序编程 正文

 

大家好,我这个网站所以经常会分享一些活动,是活动都有结束时间,刚好前段时间逛其他网站,看到对应活动有对应结束倒计时效果,活动结束后会提示活动已经结束,给用户体验是比较好的,所以也写了这个效果,分享给大家。因为考虑到大家一些网站没有使用jq,或者jq版本低之类,所以使用原生来实现效果,这样任何网站都是可以使用。

效果如下图所示:

 


给网站添加一个活动倒计时效果线报活动结束提示效果
-安生子-AnSheng
-第1
张图片

    如果活动没结束,那么显示距离结束时间,为绿色,如果到期了,那么显示 活动已经结束,为红色提示。

    下方是对应html和js代码

    将html代码span标签中的时间修改为到期时间,格式一定要正确,例如 2018-08-08 24:00:00 ,并放置需要显示的地方。

    将js代码,放置公共js中,或者其他只要引入的js文件中即可。

HTML:

<span id="ActivityDate">2020-05-08 24:00:00</span>

JavaScript:

<script> // 获取id 
    var ActivityDate = document.getElementById("ActivityDate");
    function timepiece(key) {
        var datatime = /^[d]{4}-[d]{1,2}-[d]{1,2}( [d]{1,2}:[d]{1,2}(:[d]{1,2})?)?$/ig, str = '', s;
        // 正则验证日期格式是否正确 
        if (!key.match(datatime)) { console.log('日期参数错误,请按格式填写,如 1996-10-22 24:00:00'); return }
        // 当前日期减去活动日期,判断是否超出 
        var sec = (new Date(key.replace(/-/ig, '/')).getTime() - new Date().getTime()) / 1000; if (sec < 0) { ActivityDate.innerHTML = "<span style=" + "color:red;" + ">" + "本活动已经结束" + "</span>"; return } s = { '天': sec / 24 / 3600, '时': sec / 3600 % 24, '分': sec / 60 % 60, '秒': sec % 60 } for (i in s) { if (Math.floor(s[i]) > 0) str += Math.floor(s[i]) + i; } if (Math.floor(sec) == 0) { str = '0秒'; } // 距离活动结束时间显示到页面 
        ActivityDate.innerHTML = "<span style=" + "color:#4ad564;" + ">" + "本活动还有" + str + "结束" + "</span>";
        // 每隔1秒更新一次 
        setTimeout(function () { timepiece(key) }, 1000)
    } timepiece(ActivityDate.innerHTML);
</script>

版权说明
文章采用: 《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权。
本站提供的一切软件、教程和内容信息仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络收集整理,如果您喜欢该程序和内容,请支持正版,购买注册,得到更好的正版服务。我们非常重视版权问题,如有侵权请邮件与我们联系处理。敬请谅解!

-- 展开阅读全文 --
快手六一大作战抽1元以上红包
« 上一篇
动漫之家APPv3.7.11/误入三次元的你重返二次元的动漫画神器/已去除已知广告!
下一篇 »

发表评论

HI ! 请登录
注册会员,享受下载全站资源特权。
登陆
社交账号登录

时钟

热门文章

3
EMLOG插件-蜘蛛来访统计修复版
4
5
类和接口的关系