日期:2014-05-16  浏览次数:20413 次

javascript日期处理函数,对批处理做了性能优化

????? 今天是元旦假期最后一天,明天又要上班了 ,哎!人生最大的痛苦没过于上班。

?

????? 其实网上写javascript日期格式化的博文很多,大体都看了看,都还不错。唯一遗憾的是只顾着实现了功能,没对函数进行性能优化。

?

????? 俗话说:不要重复造轮子。google上找了一个比较不错的日期格式化函数,来开始我的优化之旅吧!

?

????? google上找的这个日期函数化函数,估计大家都很眼熟,以前我也一直在用。先看看优化后和优化前的效率对比吧!

?

1、优化之前的toDate函数(字符串转换成Date对象),重复执行1万次,耗时660毫秒

?

?

2、优化之前的dateFormat函数(Date对象格式化成字符串),重复执行1万次,耗时676毫秒

?

?

3、优化过后的toDate函数,重复执行1万次,耗时122毫秒

?

?

4、优化后的dateFormat函数,重复执行1万次,耗时160毫秒

?

?

?

?????? 为什么前后差别这么大,其实我也没做多少处理,只是为批处理做了一些缓存而已,认真观察所有网上那些日期格式函数,其实都是用正则进行匹配和替换。其实正则是很耗性能的,于是我在正则匹配的地方做了缓存,把匹配值建立索引。以后就不用每次都去做正则匹配了。

?

????? 无代码无真相,接下来看看真相吧!

?

(function(window) {
    var sinojh = {
        Version : "1.2",
        Copyright : "Copyright? sino-jh 2012",
        Author : "Jeff Lan",
        Email : "jefflan@live.cn"
    };
    /**
     * 方便于添加和重写类的属性
     * @param {Object} attributes 添加的属性
     */
    Function.prototype.prototypes = function(attributes) {
        for ( var a in attributes) {
            this.prototype[a] = attributes[a];
        }
    };
    /**
     * 获取Url参数
     * @param {String} parameter 参数名
     * @return {String} 参数值
     */
    sinojh.getUrlParameter = function(parameter) {
        if (!sinojh.getUrlParameter.cache) {
            var url = window.location.href;
            var paraString = url.substring(url.indexOf("?") + 1, url.length).split("&");
            var cache = {};
            for ( var i in paraString) {
                var j = paraString[i];
                cache[j.substring(0, j.indexOf("="))] = j.substring(j.indexOf("=") + 1, j.length);
            }
            sinojh.getUrlParameter.cache = cache;
        }
        return sinojh.getUrlParameter.cache[parameter];
    };
    /**
     * 日期格式化
     * @param {Date} date 日期对象
     * @param {String} formatStyle 格式化样式
     * @return {String} 日期型字符串
     */
    sinojh.dateFormat = function(date, formatStyle) {
        formatStyle = formatStyle ? formatStyle : sinojh.dateFormat.settings.formatStyle;
        var time = {
            "M+" : date.getMonth() + 1,
            "d+" : date.getDate(),
            "h+" : date.getHours(),
            "m+" : date.getMinutes(),
            "s+" : date.getSeconds(),
            "S" : date.getMilliseconds()
        };
        if (formatStyle == sinojh.dateFormat.formatStyleCache) {
            var replaceCache = sinojh.dateFormat.replaceCache;
            if (replaceCache["y+"]) {
                formatStyle = formatStyle.replace(replaceCache["y+"].replace, (date.getFullYear() + "").substring(replaceCache["y+"].index));
            }
            for ( var k in time) {
                if (replaceCache[k]) {
                    formatStyle = formatStyle.replace(replaceCache[k].replace, replaceCache[k].replace.length == 1 ? time[k] : ("00" + time[k]).substring(("" + time[k]).length));
                }
            }
        } else {
            sinojh.dateFormat.formatStyleCache = formatStyle;
            var replaceCache = {};
            if (new RegExp("(y+)").test(formatStyle)) {
                var index = 4 - RegExp.$1.length;
                replaceCache["y+"] = {
                    replace : RegExp.$1,
                    index : index
                };
                formatStyle = formatStyle.replace(RegExp.$1, (date.getFullYear() + "").substring(index));
            }
            for ( var k in time) {
                if (new RegExp("(" + k + ")").test(formatStyle)) {