`

JavaScript设置倒计时及倒计时弹窗

阅读更多

      在前端开发中,难免会用到倒计时。如做的双十一活动,在距活动开始的半个月前需要做些宣传工作,需要告知用户优惠活动什么时候开始。这个时候就要用到倒计时,如在整站的某个页面提醒用户活动什么时候开始等。而在活动的后期,特别是在距活动结束仅有1天左右时,就要用到弹窗倒计时。这个倒计时设置在整站的首页顶部(当然也可以设置在其它地方,如首页中部等),并设置弹窗弹出10秒后自动消失,由用户决定是否点击到相应的活动页面,购买产品。

      需要的技术支持:CSS3,jQuery库;

HTML代码如下:

<section class="the_body">
    <div class="countdown">
        <h3>距中国雄于地球之日还有</h3>
        <div class="countdown_time">
          <span class="the_days"><i>0</i><i>3</i></span>
          <i class="date_text">天</i>
          <span class="the_hours"><i>0</i><i>7</i></span>
          <i class="date_text">时</i>
          <span class="the_minutes"><i>4</i><i>7</i></span>
          <i class="date_text">分</i>
          <span class="the_seconds"><i>1</i><i>1</i></span>
          <i class="date_text">秒</i>
        </div>
    </div>
</section>

css代码如下:

.the_body{width: 100%;max-width: 640px;min-width: 320px;margin: 0 auto;}
.countdown{background:#ffec20;padding: 10px 0;}
.countdown h3{margin:0;padding:5px 0;color:#f53544;text-align:center;font-size:14px;}
.countdown .countdown_time{display:block;width:100%;text-align:center;}
.countdown .countdown_time i{display:inline-block;position:relative;padding:0 3px;font-style:normal;background:#fff;
margin:0 2px;border-radius:3px;box-shadow:0px 1px 1px #ccc;border-bottom:1px solid #cfcfcf;font-weight
:bold;}
.countdown .countdown_time i:after{content:"";width:100%;border:1px solid #cfcfcf;border-width:1px 0 0;position:absolute;
bottom:1px;left:0;}
.countdown .countdown_time i:before{content:"";width:100%;border:1px solid #cfcfcf;border-width:1px 0 0;position:absolute;
bottom:3px;left:0;}
.countdown .countdown_time .date_text{background:transparent;font-weight:bold;box-shadow:none;
border-bottom:none;text-decoration:none;padding: 0;}
.countdown .countdown_time .date_text:after{content:"";border:none;}
.countdown .countdown_time .date_text:before{content:"";border:none;}

JavaScript代码如下:

<script>
function remaintime() {
  var date = new Date("Jan 1,2015 00:00:00");//设置倒计时结束时间
  var nowdate = new Date();//获取当前日期
  var remaintime = date.getTime() - nowdate.getTime();//获取现在到倒计时结束时间的毫秒数
  var remainday = Math.floor(remaintime / (1000 * 60 * 60 * 24));//计算求得剩余天数
  var remainhour = Math.floor((remaintime - remainday * 1000 * 60* 60 * 24)/ (1000 * 60 * 60));//计算求得剩余小时数
  var remainminute = Math.floor((remaintime - remainday * 1000 * 60* 60 * 24 - remainhour * 1000 * 60 * 60)/ (1000 * 60));//计算求得剩余分钟数
  var remainsecond = Math.floor((remaintime - remainday * 1000 * 60 * 60 * 24- remainhour * 1000 * 60 * 60 - remainminute *
        1000 * 60) / (1000));//计算求得剩余秒数
  //当剩余天数小于10时,就在其前加一个0,以下剩余小时数、分钟数与秒数与此相同
  if (remainday < 10) {
    remainday = "0" + remainday;
  }else{remainday+="";
  //当剩余天数大于10时,剩余天数为数值,这是需要将该值转换为字符串,以下的剩余小时数、分钟数与秒数与此相同
}
  if (remainhour < 10) {
    remainhour = "0" + remainhour;
  }else{remainhour+="";}
  if (remainminute < 10) {
    remainminute = "0" + remainminute;
  }else{remainminute+="";}
  if (remainsecond < 10) {
    remainsecond = "0" + remainsecond;
  }else{remainsecond+="";}
  $(".the_days i:first-child").html(remainday.substr(0, 1));
  $(".the_days i:last-child").html(remainday.substr(1, 2));
  $(".the_hours i:first-child").html(remainhour.substr(0, 1));
  $(".the_hours i:last-child").html(remainhour.substr(1, 2));
  $(".the_minutes i:first-child").html(remainminute.substr(0, 1));
  $(".the_minutes i:last-child").html(remainminute.substr(1, 2));
  $(".the_seconds i:first-child").html(remainsecond.substr(0, 1));
  $(".the_seconds i:last-child").html(remainsecond.substr(1, 2));
  setTimeout("remaintime()",1000);//设置1秒后调用remaintime函数
}
remaintime();
setTimeout(function(){$(".countdown").hide();},10000);//在首页设置的弹窗效果,在分页这段代码可以不设置
</script>

效果如下:


      这是我自己写的倒计时效果,当然每个人都可以根据自己的爱好,设置倒计时的效果。如你可以只显示“几天几时几分”,但个人觉得没有设置到“几天几时几分几秒”够气氛。这里的样式也都可以根据自己的喜好改动,但最终的效果都是制造活动开始前的火热氛围。

至于这里的html代码、css代码及JavaScript代码需要注意的也说下:

1.html代码就不多说,主要就是怎么设置dom,以易于JavaScript操作;

2.css代码,这里主要用了:before与:after伪类,设置倒计时数值的立体效果;

3.JavaScript代码也是很简单的一个函数,这里你需要将得到的剩余时间转换为字符串,以便于字符串的截取显示等。另外,用setTimeout函数设置隔1秒执行一次函数,以动态显示剩余时间,当然也可以用setInterval函数,这两个函数设置的效果基本相同。

      至此,一个简单的倒计时效果就做出来了。如果要在首页设置弹窗倒计时,你可以把背景设置的更炫酷一点,这样可以吸引用户点击,并设置10秒后弹窗自动消失(或者设置一个关闭按钮等)。

      倒计时的实现可以有很多种方式,在这里也就先介绍这一种,以后有时间将会继续总结。酷

  • 大小: 2.1 KB
1
0
分享到:
评论

相关推荐

    元旦倒计时代码 javascript倒计时代码及倒计时弹窗.pdf

    元旦倒计时代码 javascript倒计时代码及倒计时弹窗.pdf

    javascript实现倒计时并弹窗提示特效

    为了实现弹窗提示效果,可以使用JavaScript的定时器函数`setTimeout`或`setInterval`,在用户浏览到特定页面时触发弹窗显示倒计时剩余时间。倒计时结束后,弹窗可以自动消失,也可以让用户自行关闭。 在代码的最后...

    计时器(倒计时,正计时)demo

    2. **JavaScript计时器原理**:计时器功能通常由JavaScript的`setInterval()`或`setTimeout()`函数实现。在这个Demo中,倒计时和正计时可能通过这两个函数进行控制,`setInterval()`用于周期性执行某段代码,而`...

    dialog 弹窗-倒计时

    2. **设置倒计时逻辑**:使用编程语言中的定时器函数,如Java的`ScheduledExecutorService`,JavaScript的`setInterval`,或者React Hooks中的`useEffect`配合`setTimeout`。这些函数会在指定的间隔内执行回调,从而...

    JS按钮倒计时函数

    根据提供的文件信息,我们可以深入探讨JavaScript中的倒计时功能实现方式。倒计时在很多应用场景中都非常常见,比如在线表单提交确认、验证码发送后重新获取时间限制等场景。接下来,我们将详细介绍如何利用...

    从天数精确到秒的桌面倒计时器

    3. 实时更新:通过定时器(如JavaScript的setInterval或Python的threading模块)每隔一定时间(例如每秒)更新显示的倒计时。 4. 提醒功能:当倒计时到达零时,程序会发出声音、弹窗或其他形式的提醒,确保用户不会...

    JavaScript 实现简单的倒计时弹窗DEMO附图

    6. **页面加载后执行JavaScript**:倒计时弹窗的实现需要在页面加载后执行。在给定的文件中,通过将reboot函数绑定到window.onload事件上,确保了在页面完全加载后立即执行倒计时弹窗的显示逻辑。 通过对上述知识点...

    jquery做的倒计时和弹出窗口

    在jQuery中,我们可以利用JavaScript的Date对象和setInterval函数来实现倒计时。 以下是一个基本的jQuery倒计时示例: ```javascript $(document).ready(function() { var targetTime = new Date("2023年12月31日...

    倒计时10秒后关闭当前窗口

    标题“倒计时10秒后关闭当前窗口”所涉及的知识点主要集中在JavaScript编程语言上,特别是关于定时器(setTimeout)和DOM操作的部分。在这个场景中,开发者可能想要创建一个功能,即在用户看到警告或者确认信息后,...

    js炫酷倒计时引导页面源码

    首页设置弹窗倒计时,你可以把背景设置的更炫酷一点,这样可以吸引用户点击,并设置10秒后弹窗自动消失(或者设置一个关闭按钮等)。 倒计时的实现可以有很多种方式,在这里也就先介绍这一种,以后有时间将会继续...

    使用html,css,js实现倒计时案例,并且点击页面出现小心心

    在这个例子中,我们首先设置了倒计时的结束时间,然后使用JavaScript获取当前时间并计算剩余秒数。接着,我们根据剩余时间计算天数、小时数、分钟数和秒数,并在页面上更新。倒计时每秒更新一次,直到结束。此外,当...

    jquery倒计时广告.rar

    此外,为了确保用户体验,还应考虑一些附加功能,如在倒计时结束后自动隐藏广告元素,或者触发特定的事件(如弹窗提示用户已过期)。 总的来说,"jquery倒计时广告.rar"这个压缩包提供了一个使用jQuery实现的动态...

    BOSS刷新提醒-倒计时.zip

    在IT行业中,游戏开发是一个非常重要的领域,而“BOSS刷新提醒-倒计时”这样的功能则直指游戏系统的优化和用户体验提升。这个压缩包文件包含了一个名为“BOSS刷新提醒-倒计时.xls”的Excel表格,这通常用于管理游戏...

    距离某一时间的时间倒计时代码,当到达此时间时告诉已经到达倒计时停

    可以设置定时器(如JavaScript的`setInterval`,Python的`threading.Timer`),每隔一定时间执行一次倒计时的计算和显示。 6. **到达时间提示**: 当倒计时达到0时,应该有一个机制来通知用户倒计时已结束。这可以...

    辩论倒计时微信小程序码

    2. 倒计时功能:在小程序中实现倒计时功能,通常需要使用JavaScript的Date对象和setInterval函数。首先,根据用户设定的辩论环节(如立论、驳立论、质辩等)和相应时间,创建多个倒计时定时器。每个定时器在启动后,...

    html js 倒计时

    2. **增加结束处理**: 当倒计时结束后,可以通过弹窗提示等方式告知用户。 ```javascript if (seconds ) { alert("倒计时结束!"); clearInterval(timer); } ``` 3. **美化界面**: 使用CSS对倒计时界面进行...

    19种弹窗方式-JavaScript

    10. **轮询提示**: 在特定时间间隔重复显示弹窗,例如倒计时或定时提醒。 11. **拖放对话框**: 可以通过鼠标拖动调整位置的弹窗。 12. **可自定义大小的弹窗**: 用户可以手动调整弹窗的宽度和高度。 13. **全屏弹窗*...

    倒计时的头部全屏广告显示隐藏特效代码

    倒计时通常通过JavaScript实现,它会动态更新剩余时间,并在计时结束时执行特定操作,这里是隐藏广告。在`js`文件夹中的JavaScript代码应该包含了这一逻辑。计时器的创建通常使用`setInterval`函数,每隔一定时间...

Global site tag (gtag.js) - Google Analytics