首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >多时区显示相同时间的Momentjs

多时区显示相同时间的Momentjs
EN

Stack Overflow用户
提问于 2018-12-19 21:18:49
回答 4查看 1.3K关注 0票数 3

因此,我试图得到不同的时区,我已经设置了时间,然而,在所有区域中都显示了相同的时间。

这是我的代码:

代码语言:javascript
复制
const format = 'HH:MM'

// San Francisco - Time
let sanFrancisco = moment().tz('Etc/GMT-8').format(format)
document.querySelector('.sanFrancisco').innerHTML = sanFrancisco + ' GMT-8';

// Mexico City - Time
let mexicoCity = moment().tz('Etc/GMT-6').format(format)
document.querySelector('.mexicoCity').innerHTML = mexicoCity + ' GMT-6'

// New York City - Time
let newYorkCity = moment().tz('Etc/GMT-5').format(format)
document.querySelector('.newYork').innerHTML = newYorkCity + ' GMT-5'

// Montréal - Time
let montreal = moment().tz('Etc/GMT-5').format(format)
document.querySelector('.montreal').innerHTML = montreal + ' GMT-5'

// London - Time
let london = moment().tz('Etc/GMT+0').format(format)
document.querySelector('.london').innerHTML = london + ' GMT+0'

我现在看到的是:

至于加载,我只是使用CDN,例如:

代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.2/moment.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment-timezone/0.5.23/moment-timezone.min.js"></script>
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2018-12-19 21:32:08

由于没有使用时区加载时区,因此需要添加要使用的每个时区。要添加所有时区,只需加载以下文件:

代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment-timezone/0.5.23/moment-timezone-with-data.js"></script>

而不是:

代码语言:javascript
复制
 <script src="https://cdnjs.cloudflare.com/ajax/libs/moment-timezone/0.5.23/moment-timezone.min.js"></script>
票数 4
EN

Stack Overflow用户

发布于 2018-12-19 21:35:59

您很可能在后台得到以下错误,它不会阻止显示格式化日期,但不会添加区域偏移量:

Min.js:1 Timezone没有Etc/GMT+0的数据。见http://momentjs.com/timezone/docs/#/data-loading/

在使用时区之前,需要使用moment.tz.add()加载时区。例如,洛杉矶:

代码语言:javascript
复制
moment.tz.add('America/Los_Angeles|PST PDT|80 70|0101|1Lzm0 1zb0 Op0');
let kobe = moment().tz('America/Los_Angeles').format(format)
票数 3
EN

Stack Overflow用户

发布于 2018-12-19 21:36:48

您需要将格式从'HH:MM'更改为'HH:mm'

MM是这个月的,但是你要找的是几分钟,也就是mm

您还需要小心这些Etc/GMT-X时区中的标志。您为旧金山指定了Etc/GMT-8,但是这些时区的标志是倒置的,所以它实际上是Etc/GMT+8 (使用时区名称更好的另一个原因)。

例如:

代码语言:javascript
复制
const sf = moment().tz('America/Los_Angeles').format('HH:mm');
const sfetc = moment().tz('Etc/GMT+8').format('HH:mm');
console.log(sf);
console.log(sfetc);
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.22.2/moment.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment-timezone/0.5.23/moment-timezone-with-data.js"></script>

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/53859262

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档