js倒计时在移动端的应用

Posted 倚笑乘风

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js倒计时在移动端的应用相关的知识,希望对你有一定的参考价值。

在移动端测试倒计时,将时间转化为毫秒会在苹果手机上出现NaN

  ```
  //在安卓上这样写可以获取到的
  var date = ‘2017-06-12 13:12:13‘;
  var time = new Date(date).getTime();
  //但在苹果手机上是不支持的,必须这样写:
  var time = new Date(date.replace(/-/g,‘/‘)).getTime();
  //有时时间格式要有问题的情况下,要先用split进行切分处理。
  ```

  以下是实现代码
  ```
  var sh;
  function getStartTime(StartTime) {
      var t = Number(StartTime+172800000) - Date.now(); //时间差的毫秒数
      var d = 0,
          h = 0,
          m = 0,
          s = 0,
          ah = 0;
      if (t >= 0) {
          d = Math.floor(t / 1000 / 3600 / 24);
          h = Math.floor(t / 1000 / 60 / 60 % 24);
          m = Math.floor(t / 1000 / 60 % 60);
          s = Math.floor(t / 1000 % 60);
          ah = d*24+h;
          if (ah<10) {
            ah = ‘0‘+ah;
          }
          if (m<10) {
            m = ‘0‘+m;
          }
          if (s<10) {
            s = ‘0‘+s;
          }
          return ‘<span>‘+ah+‘</span>‘+"小时"+‘<span>‘+m+‘</span>‘+"分钟"+‘<span>‘+s+‘</span>‘+"秒";
      }else{
        return "活动已经结束";
        clearInterval(sh);
      }
  } 
  sh=setInterval(setTimeInterval,1000);    
  function setTimeInterval(){
    var time = data.RargainU.createtime.split(".")[0].replace(/-/g,‘/‘);
    var StartTime =  new Date(time).getTime();
    // 在页面中插入
    $(".time").html(getStartTime(StartTime));
  }
  setTimeInterval();
  ```

以上是关于js倒计时在移动端的应用的主要内容,如果未能解决你的问题,请参考以下文章

JUC并发编程 共享模式之工具 JUC CountdownLatch(倒计时锁) -- CountdownLatch应用(等待多个线程准备完毕( 可以覆盖上次的打印内)等待多个远程调用结束)(代码片段

带有 Node.js 后端的移动应用程序 - 为客户端开发选择啥框架?

颤振计时器仅更新秒小部件

从Hybrid到React-Native: JS在移动端的南征北战史

python使用上下文对代码片段进行计时,非装饰器

js自动切换选项卡如何实现鼠标移动到相应的内容div中,停止计时。移出后继续自动切换?