关于 js 生成 yyyy-mm-dd 格式,往往都会采取手动拼接,一般不愿意为了小功能而去动用 momentjs 之类的插件。
ps: 只分享简单方法,网上有 N 多 dateformat 代码,这里不做讨论。
假如要兼容 IE6+,通常会这么写。
function pad(s) { // 补零 return ('0' + s).slice(-2); } var dt = new Date(); var date = dt.getFullYear() + '-' + pad(dt.getMonth() + 1) + '-' + pad(dt.getDate()); date += ' '; date += pad(dt.getHours()) + ':' + pad(dt.getMinutes()) + ':' + pad(dt.getSeconds()); console.log(date); // => 2016-03-25 11:01:01
确实有点繁琐,不过最近看到 次碳酸钴
大神的文章里是这么写的。
var dt = new Date(); var date = [ [dt.getFullYear(), dt.getMonth() + 1, dt.getDate()].join('-'), [dt.getHours(), dt.getMinutes(), dt.getSeconds()].join(':') ].join(' ').replace(/(?=/b/d/b)/g, '0'); // 正则补零 (略微改动) console.log(date); // => 2016-03-25 11:01:01
瞬间逼格高了不少,比起传统方法看着舒服多了。而且正则补零,可以单独用在其他地方。
假如是 IE9+ 或现代浏览器,那就方便多了。
var dt = new Date(); dt.setMinutes(dt.getMinutes() - dt.getTimezoneOffset()); // 修正时区偏移 var date = dt.toISOString().slice(0, -5).replace(/[T]/g, ' '); console.log(date); // => 2016-03-25 11:01:01
简洁明了,而且逼格也不低。
ps: 如果你有逼格爆表的方法,还望指点一二。