• javascript计算两个时间差


    其实,javascript计算时间差的方式非常简单,如果是默认的Date()类型,直接相减就是相差的毫秒

    var d1 = new Date('2016/03/28 10:17:22');
    var d2 = new Date('2016/03/28 11:17:22');
    console.log(parseInt(d2 - d1));//两个时间相差的毫秒数
    console.log(parseInt(d2 - d1) / 1000);//两个时间相差的秒数
    console.log(parseInt(d2 - d1) / 1000 / 60);//两个时间相差的分钟数
    console.log(parseInt(d2 - d1) / 1000 / 60);//两个时间相差的小时数

    如果,拿到的不是日期类型,而是"2016-03-28 10:27:00"这种的字符串格式呢,那么就需要先将字符串转换为日期类型。

    var t1 = "2016-03-28 10:27:00";
    var d1 = t1.replace(/-/g, "/");
    var date1 = new Date(d1);


    以上得到的date1就是一个日期类型了。就可以计算了,只要再简单封装一下,就能够组合出任意的事件类型转换函数。

    如:输入字符串得到相差秒数:

    <!doctype html>
    <html>
    <head>
        <title>jQuery判断元素是隐藏的还是可见的</title>
    </head>
    <body>
    <script>
    function GetDateDiff(startTime, endTime, diffType) {
        //将xxxx-xx-xx的时间格式,转换为 xxxx/xx/xx的格式 
        startTime = startTime.replace(/-/g, "/");
        endTime = endTime.replace(/-/g, "/");
        //将计算间隔类性字符转换为小写
        diffType = diffType.toLowerCase();
        var sTime =new Date(startTime); //开始时间
        var eTime =new Date(endTime); //结束时间
        //作为除数的数字
        var timeType =1;
        switch (diffType) {
            case"second":
                timeType =1000;
            break;
            case"minute":
                timeType =1000*60;
            break;
            case"hour":
                timeType =1000*3600;
            break;
            case"day":
                timeType =1000*3600*24;
            break;
            default:
            break;
        }
        return parseInt((eTime.getTime() - sTime.getTime()) / parseInt(timeType));
    }
    alert(GetDateDiff("2016-03-28 10:30:22","2016-03-28 10:38:22","minute"));
    </script>
    </body>
    </html>
  • 相关阅读:
    Android Static分析
    hdoj 1285 确定比赛名次 【拓扑排序】
    Sqoop2安装记录
    Activiti源代码分析
    SpringBoard 无法启动应用程序(错误:-3)
    关于public、private、protected、internal
    Java基础——Statement与PrepareStatement
    无password身份验证:安全、简单且部署高速
    说说Linux文件权限那些事儿
    Android中Service概述
  • 原文地址:https://www.cnblogs.com/yangAL/p/7802834.html
Copyright © 2020-2023  润新知