js 日期与字符串互转 (网上没有的, 字符串转日期支持任意格式化字符串)

网上现有的字符串 转 Date, 都是指定的几个格式
我实现了一个任意格式的, 只需要传入格式字符串就行了, 这个你在网上找不到 害羞

网上现有的Date.prototype.format也有一个小bug, 我也去掉了


下面的代码去除了网上 Date.prototype.format 的bug, 毫秒对应三位

(网上的 SSS 只有第一个S对应毫秒, 后面两个无效, 被映射成SS, 这个绝对不是我们想要的惊恐)

为此改了if 语句 :

Date.prototype.format = function (format) {
	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(format)) {
		format = format.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
	}
	for (var k in o) {
		if (new RegExp("(" + k + ")").test(format)) {
			var replaceWith;
			if (RegExp.$1.length == 1) 
				replaceWith = o[k];
			else if (k == "S+")
				replaceWith = ("000" + o[k]).substr(("" + o[k]).length);
			else
				replaceWith = ("00"  + o[k]).substr(("" + o[k]).length);
			format = format.replace(RegExp.$1, replaceWith);
		}
	}
	return format;
}



然后提供我写的 strToDate

// inputDateStr 必须与 inputFormat 一一对应且等长
function strToDate(inputDateStr, inputFormat) {
	var cur = new Date();
	var obj = {
		y: cur.getYear(),
		M: 1,
		d: 1,
		h: 0,
		m: 0,
		s: 0,
		S: 0
	};

	// 预处理, 删除format 中 yMdhmsS 之外的字符, 同时删除str对应的字符
	var str = "";
	var format = "";
	for (var i=0; i<inputFormat.length; ++i) {
		if ("yMdhmsS".indexOf(inputFormat.charAt(i)) >= 0) {
			str += inputDateStr[i];
			format += inputFormat[i];
		}
	}

	var startIdx=0, endIdx;
	while (startIdx < format.length) {
		var startChar = format.charAt(startIdx);
		endIdx = startIdx+1;
		while (endIdx < format.length && format.charAt(endIdx) == startChar)
			++endIdx;
			
		obj[startChar] = parseInt(str.substring(startIdx, endIdx));
		
		startIdx = endIdx;
	}
	
	return new Date(obj.y, obj.M - 1, obj.d, obj.h, obj.m, obj.s, obj.S);
}


测试代码

alert(strToDate("2015-01-02 <26> 03:04:05", "yyyy-dd-MM <SS> hh:mm:ss").format("yyyy-MM-dd hh:mm:ss SSS"));



附件是这些代码的测试页面, 给个好评吧  吐舌头

可以看到我的代码风格是纯C的, 纯后端人员 大笑



  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值