JavaScript仿京东实现秒杀倒计时案例详解

 更新时间:2022年03月08日 10:17:33   作者:一夕ξ  
这篇文章主要为大家详细介绍了如何利用JavaScript实现京东秒杀倒计时效果,文中示例代码介绍的非常详细,感兴趣的小伙伴们可以参考一下

功能介绍:

1、这个倒计时是不断变化的,因此需要定时器来自动变化(setInterval)

2、三个黑色的盒子,分别存放时、分秒

3、三个盒子利用innerHTML存入倒计时

<!DOCTYPE html>
<html lang="en">
 
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div {
            background-color: black;
            width: 50px;
            height: 50px;
            margin-left: 20px;
            float: left;
            color: white;
            font-size: 20px;
            text-align: center;
            line-height: 50px;
        }
    </style>
</head>
 
<body>
    <div class='h1'></div>
    <div class='m'></div>
    <div class='s1'></div>
    <script>
        //把时间放到div中去
        var div = document.querySelectorAll('div')
        var timer1 = setInterval(function() {
            var date1 = new Date(2022, 3, 2, 18, 40, 0); //获得到点截至时间距离标准时间的毫秒数
            var date2 = new Date(); //获得目前时间距离准时间的毫秒数
            var date = (date1 - date2) / 1000; //用到点时间的毫秒数减去现在时间的毫秒数,必须先化为秒单位,之后再进行转换
            var h = parseInt((date / 60 / 60) % 24); //小时
            var m = parseInt((date / 60) % 60); //分钟
            var s = parseInt(date % 60); //秒    一定要包含在这个函数中,因为是间隔1秒就要重新算一遍,需要提高准确率的话,把秒数减少(刷新间隔)
            div[2].innerHTML = s
            div[1].innerHTML = m
            div[0].innerHTML = h
        }, [1])
    </script>
</body>
 
</html>

改进:

    <script>
        //把时间放到div中去
        var div = document.querySelectorAll('div')
        var timer1 = setInterval(fn, [1000])
        var date1 = new Date(2022, 3, 2, 18, 40, 0);
        var date2 = new Date();
        var date = (date1 - date2) / 1000;
        var h = parseInt((date / 60 / 60) % 24);
        var m = parseInt((date / 60) % 60);
        var s = parseInt(date % 60);
        div[2].innerHTML = s
        div[1].innerHTML = m
        div[0].innerHTML = h
            //解决刚刷新,数字不显示的问题
        function fn() {
            var date1 = new Date(2022, 3, 2, 18, 40, 0); //获得到点截至时间距离标准时间的毫秒数
            var date2 = new Date(); //获得目前时间距离准时间的毫秒数
            var date = (date1 - date2) / 1000; //用到点时间的毫秒数减去现在时间的毫秒数,必须先化为秒单位,之后再进行转换
            var h = parseInt((date / 60 / 60) % 24); //小时
            var m = parseInt((date / 60) % 60); //分钟
            var s = parseInt(date % 60); //秒    一定要包含在这个函数中(最好是封装一个函数),因为是间隔1秒就要重新算一遍,需要提高准确率的话,把秒数减少(刷新间隔).如果间隔比较大的话,一刷新页面,会产生空白。解决方法就是,在未调用这个函数前,先把时间放入到div盒子中   
            div[2].innerHTML = s
            div[1].innerHTML = m
            div[0].innerHTML = h
        }
    </script>

添加停止倒计时按钮:

    <button>停止倒计时</button>
 
        var btn = document.querySelector('button')
        btn.addEventListener('click', function() {
            clearInterval(timer1)
        })

到此这篇关于JavaScript仿京东实现秒杀倒计时案例详解的文章就介绍到这了,更多相关JavaScript秒杀倒计时内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Javascript confirm多种使用方法解析

    Javascript confirm多种使用方法解析

    这篇文章主要介绍了Javascript confirm多种使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • 使用UrlConnection实现后台模拟http请求的简单实例

    使用UrlConnection实现后台模拟http请求的简单实例

    这篇文章主要介绍了使用UrlConnection实现后台模拟http请求的简单实例的相关资料,需要的朋友可以参考下
    2017-01-01
  • css样式标签和js语法属性区别

    css样式标签和js语法属性区别

    css样式标签和js语法属性区别。需要的朋友可以过来参考下,希望对大家有所帮助
    2013-11-11
  • ES6学习教程之Map的常用方法总结

    ES6学习教程之Map的常用方法总结

    Map 是 ES6 中新增的一种数据结构,与 Set 一起添加,其实功能都差不多。下面这篇文章主要给大家总结介绍了关于ES6学习教程之Map的常用方法,文中通过示例代码介绍的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-08-08
  • 利用js判断数据是否是数组或字符串的常见方法

    利用js判断数据是否是数组或字符串的常见方法

    这篇文章主要给大家介绍了关于利用js判断数据是否是数组或字符串的常见方法,其实有很多方法可以判断数据是否是数组或字符串,需要的朋友可以参考下
    2023-07-07
  • Bootstrap面板学习使用

    Bootstrap面板学习使用

    这篇文章主要为大家详细介绍了Bootstrap面板的学习使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • three.js中正交与透视投影相机的实战应用指南

    three.js中正交与透视投影相机的实战应用指南

    在three.js中摄像机的作用就是不断的拍摄我们创建好的场景,然后通过渲染器渲染到屏幕中,下面这篇文章主要给大家介绍了关于three.js中正交与透视投影相机应用的相关资料,需要的朋友可以参考下
    2022-08-08
  • 深入学习JavaScript ES8中的函数式编程

    深入学习JavaScript ES8中的函数式编程

    函数式编程已经成为现代JavaScript开发中的一种主要范式,它提供了一种更清晰、更模块化、更可维护的代码编写方式,本文将深入探讨ES8中的一些关键特性,并演示如何使用这些特性进行函数式编程实践,有需要的可以参考下
    2023-09-09
  • JavaScript回调(callback)函数概念自我理解及示例

    JavaScript回调(callback)函数概念自我理解及示例

    此文适合JavaScript入门级选手阅读,在JavaScript里什么叫Callback“回调函数”,把方法b当做一个参数传递个方法a,当方法a执行完后执行另外一个指定函数(这里是b函数),感兴趣的朋友可以了解下哈
    2013-07-07
  • GoJs连线绘图模板Link使用示例详解

    GoJs连线绘图模板Link使用示例详解

    这篇文章主要为大家介绍了GoJs连线绘图模板Link使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04

最新评论