js 生成 yyyy-mm-dd 格式的的方法

  ⋅   :288  ⋅   :0  ⋅   JS

关于 js 生成 yyyy-mm-dd 格式,往往都会采取手动拼接,一般不愿意为了小功能而去动用 momentjs 之类的插件。

假如要兼容 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(/(?=bdb)/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


如需评论,请填写表单。
换一个

记住我的信息