0. 概述

因为写 JS 写得不是很频繁,所以对于一些比较常见的操作并不熟悉,例如符合格式化输出一个 Date 对象,本文就将记录一下不同的操作方式。

1. 原生 JS

原生 JS 也没有提供方便的格式化输出方法,所以需要自行修改原型进行添加:

[[email protected]]# cat prototype.js
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), //季度 
        "S": 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().Format(format) 的形式进行格式化输出 Date 类型了:

[[email protected]]# cat example-01.js
var time1 = new Date().Format("yyyy-MM-dd");
var time2 = new Date().Format("yyyy-MM-dd HH:mm:ss");

2. JQuery

如果使用 JQuery UI 的话,那么可以直接通过 DatePicker 直接格式化:

[[email protected]]# cat jquery-demo.js
$.datepicker.formatDate('yy/mm/dd', new Date());

3. Ref