博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
js 时间处理
阅读量:5072 次
发布时间:2019-06-12

本文共 7848 字,大约阅读时间需要 26 分钟。

1.格式化时间

function GetDateTimeFormatter(value) {

        if (value == undefined) {
            return "";
        }
        /*json格式时间转js时间格式*/
        value = value.substr(1, value.length - 2);
        var obj = eval('(' + "{Date: new " + value + "}" + ')');
        var dateValue = obj["Date"];
        if (dateValue.getFullYear() < 1900) {
            return "";
        }
        return dateValue.format("yyyy-mm-dd HH:MM:ss");
    }

2.获取当前时间

    function GetCurTime() {

        var d = new Date();
        var years = d.getFullYear();
        var month = add_zero(d.getMonth() + 1);
        var days = add_zero(d.getDate());
        var hours = add_zero(d.getHours());
        var minutes = add_zero(d.getMinutes());
        var seconds = add_zero(d.getSeconds());
        var ndate = years + "-" + month + "-" + days + "- " + hours + ":" + minutes + ":" + seconds;
        return ndate;
    }
    function add_zero(temp) {
        if (temp < 10) return "0" + temp;
        else return temp;
    }

3.时间比较

eg . var a = GetDateTimeFormatter(t1);

var b =GetCurTime();
if(a>b){}//这样即可

4.ie下时间兼容问题

js时间推荐格式:2000/01/01

如使用2000-01-01在ie8及以下版本,存在兼容性问题

var dateValue =  "2013-01-01 01:01:00";        var createDT = new Date(); //创建时间        createDT.setFullYear(dateValue.substr(0, 4));        createDT.setMonth(dateValue.substr(5, 2) - 1);        createDT.setDate(dateValue.substr(8, 2));        createDT.setHours(dateValue.substr(11, 2));        createDT.setMinutes(dateValue.substr(14, 2));        createDT.setSeconds(0);

 

/**     * 解析输入的dateStr,返回Date类型。     * dateStr: XXXX-XX-XX     */    function parseDate(dateStr){        var strArray = dateStr.split("-");        if(strArray.length == 3){            return new Date(strArray[0], strArray[1], strArray[2]);        }else{            return new Date();        }    }

5.Date方法扩展

/*函数:日期 加n天参数:n是天数返回:n天后的日期*/Date.prototype.addDays = Date.prototype.addDays || function (n) {     this.setDate(this.getDate() + n);    return this;}/*函数:日期 减n天参数:n是天数返回:n天后的日期*/Date.prototype.minusDays = Date.prototype.minusDays || function (n) {    this.setDate(this.getDate() - n);    return this;}/*函数:日期 加n天参数:n是天数返回:n天后的日期*/Date.prototype.getWeek = Date.prototype.getWeek || function (date) {     // var n = date.getDay();    var n = this.getDay();    var rtnStr = "";    switch (n) {        case 0: { rtnStr = "星期日"; break; }        case 1: { rtnStr = "星期一"; break; }        case 2: { rtnStr = "星期二"; break; }        case 3: { rtnStr = "星期三"; break; }        case 4: { rtnStr = "星期四"; break; }        case 5: { rtnStr = "星期五"; break; }        case 6: { rtnStr = "星期六"; break; }        default: { rtnStr = ""; break; }    }    return rtnStr;}/*函数:把字符串转换为日期对象参数:yyyy-mm-dd或yyyy/mm/dd形式的字符串返回:Date对象注:IE下不支持直接实例化日期对象,如new Date("2011-04-06")*/Date.prototype.convertDate = function (date) {    var flag = true;    var dateArray = date.split("-");    if (dateArray.length != 3) {        dateArray = date.split("/");        if (dateArray.length != 3) {            return null;        }        // flag = false;    }    var newDate = new Date();    if (flag) {        // month从0开始        newDate.setFullYear(dateArray[0], dateArray[1] - 1, dateArray[2]);    }    else {        newDate.setFullYear(dateArray[2], dateArray[1] - 1, dateArray[0]);    }    newDate.setHours(0, 0, 0);    return newDate;};/*函数:计算两个日期之间的差值参数:date是日期对象flag:ms-毫秒,s-秒,m-分,h-小时,d-天,M-月,y-年返回:当前日期和date两个日期相差的毫秒/秒/分/小时/天*/Date.prototype.dateDiff = function (date, flag) {    var msCount = 24 * 60 * 60 * 1000;    this.setHours(0, 0, 0, 0);    date.setHours(0, 0, 0, 0);    var diff = this.getTime() - date.getTime();    return Math.floor(diff / msCount);    switch (flag) {        case "ms":            msCount = 1;            break;        case "s":            msCount = 1000;            break;        case "m":            msCount = 60 * 1000;            break;        case "h":            msCount = 60 * 60 * 1000;            break;        case "d":            msCount = 24 * 60 * 60 * 1000;            break;    }    return Math.floor(diff / msCount);};/*函数:格式化日期参数:formatStr-格式化字符串d:将日显示为不带前导零的数字,如1dd:将日显示为带前导零的数字,如01ddd:将日显示为缩写形式,如Sundddd:将日显示为全名,如SundayM:将月份显示为不带前导零的数字,如一月显示为1MM:将月份显示为带前导零的数字,如01MMM:将月份显示为缩写形式,如JanMMMM:将月份显示为完整月份名,如Januaryyy:以两位数字格式显示年份yyyy:以四位数字格式显示年份h:使用12小时制将小时显示为不带前导零的数字,注意||的用法hh:使用12小时制将小时显示为带前导零的数字H:使用24小时制将小时显示为不带前导零的数字HH:使用24小时制将小时显示为带前导零的数字m:将分钟显示为不带前导零的数字mm:将分钟显示为带前导零的数字s:将秒显示为不带前导零的数字ss:将秒显示为带前导零的数字l:将毫秒显示为不带前导零的数字ll:将毫秒显示为带前导零的数字tt:显示am/pmTT:显示AM/PM返回:格式化后的日期*/Date.prototype.format = function (formatStr) {    var date = this;    /*    函数:填充0字符    参数:value-需要填充的字符串, length-总长度    返回:填充后的字符串    */    var zeroize = function (value, length) {        if (!length) {            length = 2;        }        value = new String(value);        for (var i = 0, zeros = ''; i < (length - value.length) ; i++) {            zeros += '0';        }        return zeros + value;    };    return formatStr.replace(/"[^"]*"|'[^']*'|\b(?:d{1,4}|M{1,4}|yy(?:yy)?|([hHmstT])\1?|[lLZ])\b/g, function ($0) {
switch ($0) { case 'd': return date.getDate(); case 'dd': return zeroize(date.getDate()); case 'ddd': return ['Sun', 'Mon', 'Tue', 'Wed', 'Thr', 'Fri', 'Sat'][date.getDay()]; case 'dddd': return ['Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday'][date.getDay()]; case 'M': return date.getMonth() + 1; case 'MM': return zeroize(date.getMonth() + 1); case 'MMM': return ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'][date.getMonth()]; case 'MMMM': return ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'][date.getMonth()]; case 'yy': return new String(date.getFullYear()).substr(2); case 'yyyy': return date.getFullYear(); case 'h': return date.getHours() % 12 || 12; case 'hh': return zeroize(date.getHours() % 12 || 12); case 'H': return date.getHours(); case 'HH': return zeroize(date.getHours()); case 'm': return date.getMinutes(); case 'mm': return zeroize(date.getMinutes()); case 's': return date.getSeconds(); case 'ss': return zeroize(date.getSeconds()); case 'l': return date.getMilliseconds(); case 'll': return zeroize(date.getMilliseconds()); case 'tt': return date.getHours() < 12 ? 'am' : 'pm'; case 'TT': return date.getHours() < 12 ? 'AM' : 'PM'; } });}

 6.时间戳

获取当前时间戳:第一种方法://精确到秒,毫秒用000显示
var timestamp = Date.parse(new Date()); 结果:1280977330000 第二种方法://精确到毫秒var timestamp = (new Date()).valueOf();结果:1280977330748第三种方法://精确到毫秒var timestamp=(new Date()).getTime();结果:1280977330748

有时遇到返回的时间格式是json字符串,转成时间戳:

parseInt((dateJsonStr).replace("/Date(", "").replace(")/", ""), 10); 

 时间戳转为时间、日期格式

function timestampToTime(timestamp) {        var date = new Date(timestamp * 1000);//时间戳为10位需*1000,时间戳为13位的话不需乘1000        var Y = date.getFullYear() + '-';        var M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '-';        var D = date.getDate() + ' ';        var h = date.getHours() + ':';        var m = date.getMinutes() + ':';        var s = date.getSeconds();        return Y+M+D+h+m+s;    }    timestampToTime(1403058804);    console.log(timestampToTime(1403058804));//2014-06-18 10:33:24

日期

function timestampToDate(timestamp) {        var date = new Date(timestamp * 1000);//时间戳为10位需*1000,时间戳为13位的话不需乘1000        var Y = date.getFullYear() + '-';        var M = (date.getMonth()+1 < 10 ? '0'+(date.getMonth()+1) : date.getMonth()+1) + '-';        var D = date.getDate() ;        return Y+M+D;    }    timestampToTime(1403058804);    console.log(timestampToDate(1403058804));//2014-06-18

 

注意:如果是Unix时间戳记得乘以1000。比如:PHP函数time()获得的时间戳就要乘以1000。

原文:https://www.cnblogs.com/crf-Aaron/archive/2017/11/16/7844462.html

 

 

 

 

转载于:https://www.cnblogs.com/xcsn/archive/2013/03/14/2960179.html

你可能感兴趣的文章
Windows Phone开发(4):框架和页 转:http://blog.csdn.net/tcjiaan/article/details/7263146
查看>>
Unity3D研究院之打开Activity与调用JAVA代码传递参数(十八)【转】
查看>>
python asyncio 异步实现mongodb数据转xls文件
查看>>
TestNG入门
查看>>
【ul开发攻略】HTML5/CSS3菜单代码 阴影+发光+圆角
查看>>
[ZJOI2007]棋盘制作 【最大同色矩形】
查看>>
IOS-图片操作集合
查看>>
模板统计LA 4670 Dominating Patterns
查看>>
团队项目开发客户端——登录子系统的设计
查看>>
IO—》Properties类&序列化流与反序列化流
查看>>
session如何保存在专门的StateServer服务器中
查看>>
react展示数据
查看>>
测试计划
查看>>
选择器
查看>>
Mysql与Oracle 的对比
查看>>
jquery实现限制textarea输入字数
查看>>
thinkphp5 csv格式导入导出(多数据处理)
查看>>
PHP上传RAR压缩包并解压目录
查看>>
Codeforces 719B Anatoly and Cockroaches
查看>>
jenkins常用插件汇总
查看>>