javascript Date format(js日期格式化)

javascript Date format(js日期格式化)这个很不错,好像是csdn的Meizz写的://对Date的扩展,将Date转化为指定格式的String//月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q)可以用1-2个占位符,//年(y)可以用1-4个占位符,毫秒(S)只能用1个占位符(是1-3位的数字)//例子://(newDate()).Format(“yyyy-MM-ddhh:mm:ss.S”)==>2006-07-0208:09:04.423//(newDate())

大家好,又见面了,我是你们的朋友全栈君。

方法一:这个很不错,好像是 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.423 // (new Date()).Format(“yyyy-M-d h:m:s.S”) ==> 2006-7-2 8:9:4.18 Date.prototype.Format = function(fmt) { //author: meizz 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; }

 

 

调用方法:

var time1 = new Date().format(“yyyy-MM-dd HH:mm:ss”); var time2 = new Date().format(“yyyy-MM-dd”);

 

方法二:

<mce:script language=”javascript” type=”text/javascript”><!– /** * 对Date的扩展,将 Date 转化为指定格式的String * 月(M)、日(d)、12小时(h)、24小时(H)、分(m)、秒(s)、周(E)、季度(q) 可以用 1-2 个占位符 * 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字) * eg: * (new Date()).pattern(“yyyy-MM-dd hh:mm:ss.S”) ==> 2006-07-02 08:09:04.423 * (new Date()).pattern(“yyyy-MM-dd E HH:mm:ss”) ==> 2009-03-10 二 20:09:04 * (new Date()).pattern(“yyyy-MM-dd EE hh:mm:ss”) ==> 2009-03-10 周二 08:09:04 * (new Date()).pattern(“yyyy-MM-dd EEE hh:mm:ss”) ==> 2009-03-10 星期二 08:09:04 * (new Date()).pattern(“yyyy-M-d h:m:s.S”) ==> 2006-7-2 8:9:4.18 */ Date.prototype.pattern=function(fmt) { var o = { “M+” : this.getMonth()+1, //月份 “d+” : this.getDate(), //日 “h+” : this.getHours()%12 == 0 ? 12 : this.getHours()%12, //小时 “H+” : this.getHours(), //小时 “m+” : this.getMinutes(), //分 “s+” : this.getSeconds(), //秒 “q+” : Math.floor((this.getMonth()+3)/3), //季度 “S” : this.getMilliseconds() //毫秒 }; var week = { “0” : “/u65e5”, “1” : “/u4e00”, “2” : “/u4e8c”, “3” : “/u4e09”, “4” : “/u56db”, “5” : “/u4e94”, “6” : “/u516d” }; if(/(y+)/.test(fmt)){ fmt=fmt.replace(RegExp.$1, (this.getFullYear()+””).substr(4 – RegExp.$1.length)); } if(/(E+)/.test(fmt)){ fmt=fmt.replace(RegExp.$1, ((RegExp.$1.length>1) ? (RegExp.$1.length>2 ? “/u661f/u671f” : “/u5468”) : “”)+week[this.getDay()+””]); } 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; } var date = new Date(); window.alert(date.pattern(“yyyy-MM-dd hh:mm:ss”)); // –></mce:script>

 

方法三:

Date.prototype.format = function(mask) { var d = this; var zeroize = function (value, length) { if (!length) length = 2; value = String(value); for (var i = 0, zeros = ”; i < (length – value.length); i++) { zeros += ‘0’; } return zeros + value; }; return mask.replace(/”[^”]*”|'[^’]*’|/b(?:d{1,4}|m{1,4}|yy(?:yy)?|([hHMstT])/1?|[lLZ])/b/g, function($0) { switch($0) { case ‘d’: return d.getDate(); case ‘dd’: return zeroize(d.getDate()); case ‘ddd’: return [‘Sun’,’Mon’,’Tue’,’Wed’,’Thr’,’Fri’,’Sat’][d.getDay()]; case ‘dddd’: return [‘Sunday’,’Monday’,’Tuesday’,’Wednesday’,’Thursday’,’Friday’,’Saturday’][d.getDay()]; case ‘M’: return d.getMonth() + 1; case ‘MM’: return zeroize(d.getMonth() + 1); case ‘MMM’: return [‘Jan’,’Feb’,’Mar’,’Apr’,’May’,’Jun’,’Jul’,’Aug’,’Sep’,’Oct’,’Nov’,’Dec’][d.getMonth()]; case ‘MMMM’: return [‘January’,’February’,’March’,’April’,’May’,’June’,’July’,’August’,’September’,’October’,’November’,’December’][d.getMonth()]; case ‘yy’: return String(d.getFullYear()).substr(2); case ‘yyyy’: return d.getFullYear(); case ‘h’: return d.getHours() % 12 || 12; case ‘hh’: return zeroize(d.getHours() % 12 || 12); case ‘H’: return d.getHours(); case ‘HH’: return zeroize(d.getHours()); case ‘m’: return d.getMinutes(); case ‘mm’: return zeroize(d.getMinutes()); case ‘s’: return d.getSeconds(); case ‘ss’: return zeroize(d.getSeconds()); case ‘l’: return zeroize(d.getMilliseconds(), 3); case ‘L’: var m = d.getMilliseconds(); if (m > 99) m = Math.round(m / 10); return zeroize(m); case ‘tt’: return d.getHours() < 12 ? ‘am’ : ‘pm’; case ‘TT’: return d.getHours() < 12 ? ‘AM’ : ‘PM’; case ‘Z’: return d.toUTCString().match(/[A-Z]+$/); // Return quoted strings with the surrounding quotes removed default: return $0.substr(1, $0.length – 2); } }); };

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/131657.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • pycharm 2021.4.14激活码失效_通用破解码「建议收藏」

    pycharm 2021.4.14激活码失效_通用破解码,https://javaforall.cn/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

  • InetAddress类[通俗易懂]

    InetAddress类[通俗易懂]基本概念1.InetAddress位于java.net包下2.InetAddress用来代表一个IP地址,一个InetAddress对象就代表着一个IP地址3.实例化InetAddress的方法是:调用InetAddress.getByName(Stringhost);4.获取IP对应的域名:用InetAddress的实例化对象调用getHostName();5.获取IP的地址:用In…

  • ByteBuffer的用法[通俗易懂]

    ByteBuffer的用法[通俗易懂]ByteBuffer也许很多人不常用,其实它是最常用的缓冲区,可以负责缓冲存储一段数据,供数据的写入和读取。ByteBuffer是NIO里用得最多的Buffer。ByteBuffer最核心的方法是put(byte)和get()。分别是往ByteBuffer里写一个字节,和读一个字节。值得注意的是,ByteBuffer的读写模式是分开的,正常的应用场景是:往ByteBuffer里写一些数

  • 函数和方法的区别「建议收藏」

    函数和方法的区别classFoo(object):def__init__(self):self.name="haiyan"deffunc(self):print(s

  • c语言hello world代码(代码编程入门)

    usingSystem;usingSystem.Collections.Generic;publicclassMyClass{ structName{ publicstringFirstName; publicstringLastName; publicstringGetName(){ returnFirstName+”·”+LastName; } } structVector3{ publicfloatx;

  • win10工作站和服务器版对比_服务器类型

    win10工作站和服务器版对比_服务器类型Win10面世已经四年多了,越升级越卡,已经成为大家的共同评价。硬盘飙升100%、经常性C位卡顿、无端端的进程崩溃……每一次升级似乎都变成了一道选择题,升or不升?呵呵,这的确是个问题。几天前,有位网友向小编推荐了一款Win10版本,试用后发现这是真的牛!久违了的丝滑体验、硬盘评分大幅提升。最关键的是,这个版本一直在紧跟微软开发节奏,不像之前的LTSB版和LTSC版那样存在明显的功能缺失。非常适合…

    2022年10月24日

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号