Timezone
時區新增 dayjs.tz
.tz
.tz.guess
.tz.setDefault
API,用於在時區之間解析或顯示。
var utc = require('dayjs/plugin/utc')
var timezone = require('dayjs/plugin/timezone') // dependent on utc plugin
dayjs.extend(utc)
dayjs.extend(timezone)
const timestamp = "2014-06-01 12:00"
const tz = "America/New_York"
const dayjsLocal = dayjs(timestamp); //assumes UTC
//dayjsLocal.toISOString() -> 2014-06-01T12:00:00.000Z
//dayjsLocal.format('YYYY-MM-DDTHH:mm:ss') -> 2014-06-01T12:00:00
const dayjsAmerica = dayjsLocal.tz(tz) //existing time treated as UTC
//dayjsAmerica.toISOString() -> 2014-06-01T12:00:00.000Z
//dayjsAmerica.format('YYYY-MM-DDTHH:mm:ss') -> 2014-06-01T08:00:00
const dayjsAmericaKeep = dayjsLocal.tz(tz, true) //existing time treated as local time
//dayjsAmericaKeep.toISOString() -> 2014-06-01T16:00:00.000Z
//dayjsAmericaKeep.format('YYYY-MM-DDTHH:mm:ss') -> 2014-06-01T12:00:00
猜測使用者時區
dayjs.tz.guess()
在時區中解析
const d1 = dayjs.tz('2013-11-18 11:55', 'Asia/Taipei')
d1.format() // => 2013-11-18T11:55:00+08:00
d1.toISOString() // => 2013-11-18T03:55:00.000Z
轉換至時區
const d2 = dayjs.utc('2013-11-18 11:55').tz('Asia/Taipei')
d2.format() // => 2013-11-18T19:55:00+08:00
d2.toISOString() // => 2013-11-18T11:55:00.000Z
設定/重設預設時區(由「tz」使用)
// Setting the default timezone
dayjs.tz.setDefault('America/New_York')
// Resetting the default timezone to the system timezone
dayjs.tz.setDefault()
與 moment 的差異
使用預設時區會讓 moment(dateValue)
使用此時區(但 moment.tz(dateValue, timezone)
仍需要第二個參數)。
但 dayjs(dateValue)
永遠使用當地時區,即使使用了 dayjs.tz.setDefault
;只有 dayjs.tz(dateValue)
(沒有第二個參數)會使用預設時區。