tinydate.js[v0.1]关于Javascript Date的工具

编写初衷

JavaScript的Date对象所提供的方法无法满足生产的需要,比如他的Month,他的日期加减,比如我要得到1993年1月1日到现在有多少天,比如我想知道我在这个世界上活了多少个小时,那么都需要“换算”。先得到时间戳,然后在换算~~~

  • 其实只是将常用的操作,写成了js,代码复用减轻工作量。

它的功能

  • TimeStamp

    直接获取某个时间戳、时间对象、时间字符串的年月日时分秒毫秒,完整的年月日时分秒毫秒。

  • 计算时间差

    调用时间差函数会计算两个时间的差值,返回值是 TimeStamp对象(自定义的)

  • 日期格式化

    调用格式化函数可以对日期进行格式化

  • 添加年、月、日、时、分、秒

    将Date原有的setYear...等函数进行拓展,时常会有一种需求去添加某个类型的时间,但是~经常要我们写成 date.setYear(date.getFullYear()+year);非常令人讨厌的一段,封装后只需要date.addYear(year);即可。

代码

Date.prototype.format = function (fmt) {
    var o = {
        "M+": this.getMonth() + 1,                 //月份
        "d+": this.getDate(),                    //日
        "H+": this.getHours(),                   //小时
        "m+": this.getMinutes(),                 //分
        "s+": this.getSeconds(),                 //秒
        "q+": Math.floor((this.getMonth() + 3) / 3), //季度
        "f+": this.getMilliseconds()             //毫秒
    };
    if (/(y+)/.test(fmt)) {
        fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
    }
    for (var k in o) {
        if (new RegExp("(" + k + ")").test(fmt)) {
            fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
        }
    }
    return fmt;
}
//当前完整时间
Date.prototype.$nowDate = new Date().format("yyyy-MM-dd HH:mm:ss.ffff");
//获取自定义格式的当前时间
Date.prototype.$now = function (fmt) {
    return new Date().format(fmt);
}
//计算时间差
Date.prototype.diff = function (sDate, eDate) {
    if (eDate == undefined || eDate == null)
        eDate = new Date();
    var stime = sDate.getTime();
    var etime = eDate.getTime();

    var diffTime = etime - stime;

    var timeSpan = new TimeSpan(diffTime);
    return timeSpan;
}
//添加年
Date.prototype.addYear = function (number) {
    this.setFullYear(this.getFullYear() + number);
}
//添加月
Date.prototype.addMonth = function (number){
    this.setMonth(this.getMonth()+number);
}
//添加日
Date.prototype.addDate = function (number){
    this.setDate(this.getDate()+number);
}
//添加小时
Date.prototype.addHours = function (number){
    this.setHours(this.getHours()+number);
}
//添加分
Date.prototype.addMinutes = function (number){
    this.setMinutes(this.getMinutes()+number);
}
//添加秒
Date.prototype.addSeconds = function (number){
    this.setSeconds(this.getSeconds()+number);
}
//添加毫秒
Date.prototype.addMilliseconds = function (number){
    this.setMilliseconds(this.getMilliseconds()+number);
}

//获得一年中第一天的日期
Date.prototype.getTheFirstDateOfTheYear = function (date) {
    var year, month=0, day=1;
    if (date == undefined || date == null) {
        year = this.getFullYear();
    }
    else {
        year = date.getFullYear();
    }

    return new Date(year, month, day);
}
//获得一年中最后一天的日期
Date.prototype.getTheLastDateOfTheYear = function (date) {
    var year, month = 11, day = 31;
    if (date == undefined || date == null) {
        year = this.getFullYear();
    }
    else {
        year = date.getFullYear();
    }

    return new Date(year, month, day);
}
//格式化当前日期 为 时限对象
Date.prototype.timeSpan = function () {
    return new TimeSpan(this);
}
//时限对象
function TimeSpan() {
    var o = new Object();
    o.year = 0;//年
    o.month = 0;//月
    o.day = 0;//日
    o.hours = 0;//时
    o.minutes = 0;//分
    o.seconds = 0;//秒
    o.milliseconds = 0;//毫秒
    o.totalYear = 0.00;//从时间原点的年
    o.totalMonth = 0.00;//从时间原点到现在的月
    o.totalDay = 0.00;//从时间原点到现在的天
    o.totalHours = 0.00;//从时间原点到现在的小时
    o.totalMinutes = 0.00;//从时间原点到现在的分
    o.totalSeconds = 0.00;//从时间原点到现在的秒
    o.totalMilliseconds = 0.00;//从时间原点到现在的毫秒
    //初始化对象
    o.init = function (timestamp) {
        var odate = new Date(timestamp);
        o.year = odate.getFullYear();
        o.month = odate.getMonth() + 1;
        o.day = odate.getDate();
        o.hours = odate.getHours();
        o.minutes = odate.getMinutes();
        o.seconds = odate.getSeconds();
        o.milliseconds = odate.getMilliseconds();

        o.totalMilliseconds = timestamp;
        o.totalSeconds = (timestamp / 1000).toFixed(2);
        o.totalMinutes = (timestamp / 1000 / 60).toFixed(2);
        o.totalHours = (timestamp / 1000 / 60 / 60).toFixed(2);
        o.totalDay = (timestamp / 1000 / 60 / 60 / 24).toFixed(2);
        o.totalMonth = o.year * 12;
        o.totalYear = o.year;
    }
    //无参则返回空对象
    if (arguments.length == 0) {

    }
    else if (typeof (arguments[0]) === "string") {
        o.init(new Date(arguments[0]));
    }
    else if (typeof (arguments[0]) === "number") {
        o.init(arguments[0]);
    } else if (typeof(arguments[0]) === "object") {
        o.init(arguments[0]);
    }
    return o;
}

原文地址:https://www.cnblogs.com/nozer1993/p/9184280.html

时间: 2024-10-11 14:43:07

tinydate.js[v0.1]关于Javascript Date的工具的相关文章

tinydate.js[v0.2] 优化了调用方式

存在的问题 调用方式过于繁琐,部分函数需要实例化后才能调用,这个与便利的初衷不符合,所以做出如下调整. tinydate.js v0.2 Date.prototype.format = function (fmt) { var o = { "M+": this.getMonth() + 1, //月份 "d+": this.getDate(), //日 "H+": this.getHours(), //小时 "m+": thi

javascript Date format(js日期格式化)

方法一:这个很不错,好像是 csdn 的 Meizz 写的: // 对Date的扩展,将 Date 转化为指定格式的String // 月(M).日(d).小时(h).分(m).秒(s).季度(q) 可以用 1-2 个占位符, // 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字) // 例子: // (new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.4

javaScript系列:js中获取时间new Date()详细介绍

var myDate = new Date();myDate.getYear(); //获取当前年份(2位)myDate.getFullYear(); //获取完整的年份(4位,1970-????)myDate.getMonth(); //获取当前月份(0-11,0代表1月)myDate.getDate(); //获取当前日(1-31)myDate.getDay(); //获取当前星期X(0-6,0代表星期天) 何问起 hovertree.commyDate.getTime(); //获取当前时

Node.js v0.10.31API手册-Domain

Node.js v0.10.31API手册-目录 Domain(域) Domains 提供了一种方式,即以一个单一的组的形式来处理多个不同的IO操作.如果任何一个注册到domain的事件触发器或回调触发了一个'error'事件,或者抛出一个错误,那么domain对象将会被通知到.而不是直接让这个错误的上下文从`process.on('uncaughtException')'处理程序中丢失掉,也不会致使程序因为这个错误伴随着错误码立即退出. 警告: 不要忽视错误! Domain error处理程序

JavaScript Date对象介绍

Date 日期和时间对象 1. 介绍 Date对象,是操作日期和时间的对象.Date对象对日期和时间的操作只能通过方法. 2. 构造函数 2.1 new Date() :返回当前的本地日期和时间 参数:无 返回值: {Date} 返回一个表示本地日期和时间的Date对象. 示例: var dt = new Date(); console.log(dt); // => 返回一个表示本地日期和时间的Date对象 2.2 new Date(milliseconds) :把毫秒数转换为Date对象 参数

用于JS日期格式化,以及简单运算的Date包装工具类

1. [文件] yDate.js/** * | yDate.js | Copyright (c) 2013 yao.yl | email: [email protected] | Date: 2012-09-03 | */(function(global) {     var objectPrototypeToString = Object.prototype.toString;     var isDate = function(value) {        return objectPro

js中获取时间new Date()详细介绍

var myDate = new Date();myDate.getYear(); //获取当前年份(2位)myDate.getFullYear(); //获取完整的年份(4位,1970-????)myDate.getMonth(); //获取当前月份(0-11,0代表1月)         // 所以获取当前月份是myDate.getMonth()+1; myDate.getDate(); //获取当前日(1-31)myDate.getDay(); //获取当前星期X(0-6,0代表星期天)m

javascript Date对象 之 设置时间

之前对js的date对象总是感觉熟悉,而不愿细细深究其所以然,所以每当自己真正应用起来的时候,总会糊里糊涂的,今日花费2个小时的时间仔细钻研了一下,感觉 豁然开朗,故,以此记录,一来 供以后查阅,二来 给跟我有同感的同志们 供参考(代码copy到本地即可测试): javascript Date对象 --> 设置时间: 测试代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&

小程序 js中获取时间new date()的用法(网络复制过来自用)

js中获取时间new date()的用法 获取时间: 1 var myDate = new Date();//获取系统当前时间 获取特定格式的时间: 1 myDate.getYear(); //获取当前年份(2位) 2 myDate.getFullYear(); //获取完整的年份(4位,1970-????) 3 myDate.getMonth(); //获取当前月份(0-11,0代表1月) 4 myDate.getDate(); //获取当前日(1-31) 5 myDate.getDay();