js 時間處理


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:將日顯示為不帶前導零的數字,如1
dd:將日顯示為帶前導零的數字,如01
ddd:將日顯示為縮寫形式,如Sun
dddd:將日顯示為全名,如Sunday
M:將月份顯示為不帶前導零的數字,如一月顯示為1
MM:將月份顯示為帶前導零的數字,如01
MMM:將月份顯示為縮寫形式,如Jan
MMMM:將月份顯示為完整月份名,如January
yy:以兩位數字格式顯示年份
yyyy:以四位數字格式顯示年份
h:使用12小時制將小時顯示為不帶前導零的數字,注意||的用法
hh:使用12小時制將小時顯示為帶前導零的數字
H:使用24小時制將小時顯示為不帶前導零的數字
HH:使用24小時制將小時顯示為帶前導零的數字
m:將分鍾顯示為不帶前導零的數字
mm:將分鍾顯示為帶前導零的數字
s:將秒顯示為不帶前導零的數字
ss:將秒顯示為帶前導零的數字
l:將毫秒顯示為不帶前導零的數字
ll:將毫秒顯示為帶前導零的數字
tt:顯示am/pm
TT:顯示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

 

 

 


 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM