zoukankan      html  css  js  c++  java
  • 【转载】JS时间工具类收藏(时间转换、倒计时)

    **
     * =====================================
     * 日期相关方法
     * Author:  http://www.cnblogs.com/liuxianan/p/js-date-format-parse.html
     * =====================================
     */
    ; (function ($) {
        $.extend({
            /**
             * 将日期格式化成指定格式的字符串
             * @param date 要格式化的日期,不传时默认当前时间,也可以是一个时间戳
             * @param fmt 目标字符串格式,支持的字符有:y,M,d,q,w,H,h,m,S,默认:yyyy-MM-dd HH:mm:ss
             * @returns 返回格式化后的日期字符串
             *   formatDate(); // 2016-09-02 13:17:13
             *   formatDate(new Date(), 'yyyy-MM-dd'); // 2016-09-02
             *   formatDate(new Date(), 'yyyy-MM-dd 第q季度 www HH:mm:ss:SSS');// 2016-09-02 第3季度 星期五 13:19:15:792
             *   formatDate(1472793615764); // 2016-09-02 13:20:15
             */
            formatDate: function (date, fmt) {
                date = date == undefined ? new Date() : date;
                date = typeof date == 'number' ? new Date(date) : date;
                fmt = fmt || 'yyyy-MM-dd HH:mm:ss';
                var obj =
                {
                    'y': date.getFullYear(), // 年份,注意必须用getFullYear
                    'M': date.getMonth() + 1, // 月份,注意是从0-11
                    'd': date.getDate(), // 日期
                    'q': Math.floor((date.getMonth() + 3) / 3), // 季度
                    'w': date.getDay(), // 星期,注意是0-6
                    'H': date.getHours(), // 24小时制
                    'h': date.getHours() % 12 == 0 ? 12 : date.getHours() % 12, // 12小时制
                    'm': date.getMinutes(), // 分钟
                    's': date.getSeconds(), //
                    'S': date.getMilliseconds() // 毫秒
                };
                var week = ['天', '一', '二', '三', '四', '五', '六'];
                for (var i in obj) {
                    fmt = fmt.replace(new RegExp(i + '+', 'g'), function (m) {
                        var val = obj[i] + '';
                        if (i == 'w') return (m.length > 2 ? '星期' : '周') + week[val];
                        for (var j = 0, len = val.length; j < m.length - len; j++) val = '0' + val;
                        return m.length == 1 ? val : val.substring(val.length - m.length);
                    });
                }
                return fmt;
            },
            /**
             * 将字符串解析成日期
             * @param str 输入的日期字符串,如'2014-09-13'
             * @param fmt 字符串格式,默认'yyyy-MM-dd',支持如下:y、M、d、H、m、s、S,不支持w和q
             * @returns 解析后的Date类型日期
             *   parseDate('2016-08-11'); // Thu Aug 11 2016 00:00:00 GMT+0800
             *   parseDate('2016-08-11 13:28:43', 'yyyy-MM-dd HH:mm:ss') // Thu Aug 11 2016 13:28:43 GMT+0800
             */
            parseDate: function (str, fmt) {
                fmt = fmt || 'yyyy-MM-dd';
                var obj = { y: 0, M: 1, d: 0, H: 0, h: 0, m: 0, s: 0, S: 0 };
                fmt.replace(/([^yMdHmsS]*?)(([yMdHmsS])3*)([^yMdHmsS]*?)/g, function (m, $1, $2, $3, $4, idx, old) {
                    str = str.replace(new RegExp($1 + '(\d{' + $2.length + '})' + $4), function (_m, _$1) {
                        obj[$3] = parseInt(_$1);
                        return '';
                    });
                    return '';
                });
                obj.M--; // 月份是从0开始的,所以要减去1
                var date = new Date(obj.y, obj.M, obj.d, obj.H, obj.m, obj.s);
                if (obj.S !== 0) date.setMilliseconds(obj.S); // 如果设置了毫秒
                return date;
            },
            /**
             * 将一个日期格式化成友好格式,比如,1分钟以内的返回“刚刚”,
             * 当天的返回时分,当年的返回月日,否则,返回年月日
             * @param {Object} date
             */
            formatDateToFriendly: function (date) {
                date = date || new Date();
                date = typeof date === 'number' ? new Date(date) : date;
                var now = new Date();
                if ((now.getTime() - date.getTime()) < 60 * 1000) return '刚刚'; // 1分钟以内视作“刚刚”
                var temp = this.formatDate(date, 'yyyy年M月d');
                if (temp == this.formatDate(now, 'yyyy年M月d')) return this.formatDate(date, 'HH:mm');
                if (date.getFullYear() == now.getFullYear()) return this.formatDate(date, 'M月d日');
                return temp;
            },
            /**
             * 将一段时长转换成友好格式,如:
             * 147->“2分27秒”
             * 1581->“26分21秒”
             * 15818->“4小时24分”
             * @param {Object} second
             */
            formatDurationToFriendly: function (second) {
                if (second < 60) return second + '秒';
                else if (second < 60 * 60) return (second - second % 60) / 60 + '分' + second % 60 + '秒';
                else if (second < 60 * 60 * 24) return (second - second % 3600) / 60 / 60 + '小时' + Math.round(second % 3600 / 60) + '分';
                return (second / 60 / 60 / 24).toFixed(1) + '天';
            },
            /** 
             * 将时间转换成MM:SS形式 
             */
            formatTimeToFriendly: function (second) {
                var m = Math.floor(second / 60);
                m = m < 10 ? ('0' + m) : m;
                var s = second % 60;
                s = s < 10 ? ('0' + s) : s;
                return m + ':' + s;
            },
            /**
             * 判断某一年是否是闰年
             * @param year 可以是一个date类型,也可以是一个int类型的年份,不传默认当前时间
             */
            isLeapYear: function (year) {
                if (year === undefined) year = new Date();
                if (year instanceof Date) year = year.getFullYear();
                return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0);
            },
            /**
             * 获取某一年某一月的总天数,没有任何参数时获取当前月份的
             * 方式一:$.getMonthDays();
             * 方式二:$.getMonthDays(new Date());
             * 方式三:$.getMonthDays(2013, 12);
             */
            getMonthDays: function (date, month) {
                var y, m;
                if (date == undefined) date = new Date();
                if (date instanceof Date) {
                    y = date.getFullYear();
                    m = date.getMonth();
                }
                else if (typeof date == 'number') {
                    y = date;
                    m = month - 1;
                }
                var days = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]; // 非闰年的一年中每个月份的天数
                //如果是闰年并且是2月
                if (m == 1 && this.isLeapYear(y)) return days[m] + 1;
                return days[m];
            },
            /**
             * 计算2日期之间的天数,用的是比较毫秒数的方法
             * 传进来的日期要么是Date类型,要么是yyyy-MM-dd格式的字符串日期
             * @param date1 日期一
             * @param date2 日期二
             */
            countDays: function (date1, date2) {
                var fmt = 'yyyy-MM-dd';
                // 将日期转换成字符串,转换的目的是去除“时、分、秒”
                if (date1 instanceof Date && date2 instanceof Date) {
                    date1 = this.format(fmt, date1);
                    date2 = this.format(fmt, date2);
                }
                if (typeof date1 === 'string' && typeof date2 === 'string') {
                    date1 = this.parse(date1, fmt);
                    date2 = this.parse(date2, fmt);
                    return (date1.getTime() - date2.getTime()) / (1000 * 60 * 60 * 24);
                }
                else {
                    console.error('参数格式无效!');
                    return 0;
                }
            },
    
            /* by liujun 2015-10-27 
            * 倒计时的实现
            *
            *
            *         *var zxx = {
            *                $: function (id) {
            *                    return document.getElementById(id);
            *                },
            *                futureDate: Date.UTC(2015, 12, 1, 10),
            *                obj: function () {
            *                    return {
            *                        sec: zxx.$("sec"),
            *                        mini: zxx.$("mini"),
            *                        hour: zxx.$("hour"),
            *                        day: zxx.$("day")
            *                    }
            *                }
            *            };
            *            timeCountDown(zxx.futureDate, zxx.obj());
            */
            timeCountDown : function (d, o) {
                var f = {
                    zero: function (n) {
                        var n = parseInt(n, 10);
                        if (n > 0) {
                            if (n <= 9) {
                                n = "0" + n;
                            }
                            return String(n);
                        } else {
                            return "00";
                        }
                    },
                    dv: function () {
                        d = d || Date.UTC(2050, 0, 1); //如果未定义时间,则我们设定倒计时日期是2050年1月1日
                        var future = new Date(d), now = new Date();//取得将来时间对像和当前时间对像
                        //现在将来秒差值
                        var dur = Math.round((future.getTime() - now.getTime()) / 1000) + future.getTimezoneOffset() * 60, pms = {
                            sec: "00",
                            mini: "00",
                            hour: "00",
                            day: "00",
                            month: "00",
                            year: "0"
                        };
                        if (dur > 0) {
                            pms.sec = f.zero(dur % 60);
                            pms.mini = Math.floor((dur / 60)) > 0 ? f.zero(Math.floor((dur / 60)) % 60) : "00";
                            pms.hour = Math.floor((dur / 3600)) > 0 ? f.zero(Math.floor((dur / 3600)) % 24) : "00";
                            pms.day = Math.floor((dur / 86400)) > 0 ? f.zero(Math.floor((dur / 86400)) % 30) : "00";
                            //月份,以实际平均每月秒数计算
                            pms.month = Math.floor((dur / 2629744)) > 0 ? f.zero(Math.floor((dur / 2629744)) % 12) : "00";
                            //年份,按按回归年365天5时48分46秒算
                            pms.year = Math.floor((dur / 31556926)) > 0 ? Math.floor((dur / 31556926)) : "0";
                        }
                        return pms;
                    },
                    ui: function () {
                        if (o.sec) {
                            o.sec.innerHTML = f.dv().sec;
                        }
                        if (o.mini) {
                            o.mini.innerHTML = f.dv().mini;
                        }
                        if (o.hour) {
                            o.hour.innerHTML = f.dv().hour;
                        }
                        if (o.day) {
                            o.day.innerHTML = f.dv().day;
                        }
                        if (o.month) {
                            o.month.innerHTML = f.dv().month;
                        }
                        if (o.year) {
                            o.year.innerHTML = f.dv().year;
                        }
                        setTimeout(f.ui, 1000);
                    }
                };
                f.ui();
            }
        });
    })(jQuery);
  • 相关阅读:
    Linux服务器使用tar加密压缩文件
    ssh-copy-id使用非默认22端口
    Nginx日志分割脚本
    MySQL的yum源
    vSphere Client开启虚拟机提示:出现了常规系统错误: 由于目标计算机积极拒绝,无法连接。
    ESXi主机遗忘密码重置密码
    扩容swap交换分区空间
    ESXi上的固态硬盘识别为非SSD
    VMware Vcenter Server 6.0忘记密码
    Centos6与Centos7区别
  • 原文地址:https://www.cnblogs.com/xurongjian/p/9931354.html
Copyright © 2011-2022 走看看