javascript - 每个地区的人都一样的Javascript倒计时
问题描述
目前我有一个倒数计时器,唯一的问题是我输入的日期和时间与居住在其他地方的人不同时结束,会将 javascript 解释为他们的时区。有没有办法解决这个问题?当前脚本:
var countDownDate = new Date("Jul 30, 2020 20:00:00").getTime();
var x = setInterval(function() {
var now = new Date().getTime();
var distance = countDownDate - now;
var days = Math.floor(distance / (1000 * 60 * 60 * 24));
var hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
var minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
var seconds = Math.floor((distance % (1000 * 60)) / 1000);
document.getElementById("countdown").innerHTML = days + "d " + hours + "h "
+ minutes + "m " + seconds + "s ";
if (distance < 0) {
clearInterval(x);
document.getElementById("countdown").innerHTML = "EXPIRED";
}
}, 1000);
<p id="countdown"></p>
解决方案
为您的字符串添加一个明确的时区(例如 UTC-0000)
// Add an explicit timezone to your string (eg. UTC-0000)
var countDownDate = new Date("Jul 30, 2020 20:00:00 UTC-0000").getTime();
var x = setInterval(function() {
var now = new Date().getTime();
var distance = countDownDate - now;
var days = Math.floor(distance / (1000 * 60 * 60 * 24));
var hours = Math.floor((distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
var minutes = Math.floor((distance % (1000 * 60 * 60)) / (1000 * 60));
var seconds = Math.floor((distance % (1000 * 60)) / 1000);
document.getElementById("countdown").innerHTML = days + "d " + hours + "h "
+ minutes + "m " + seconds + "s ";
if (distance < 0) {
clearInterval(x);
document.getElementById("countdown").innerHTML = "EXPIRED";
}
}, 1000);
<p id="countdown"></p>
推荐阅读
- sql-server - 在 SQL Server 中用新的 Int FK 替换 varchar FK
- php - Yii2 - 测验 - 使用多对多表
- git - 拉取请求不作为 Github 中的合并(但不是 Bitbucket/Gitlab)
- javascript - 这种在对象中声明 JavaScript 函数的方式是什么?
- swift - 由于“内部”保护级别切换语句,Alamofire 的“值”无法访问
- excel - VBA:从 Excel 到 PowerPoint 的 PasteSpecial 带有“形状(未知成员):无效请求”。错误
- firebase - Firestore - 使用 ADMIN SDK 执行的 R&W 操作是否有任何费用
- laravel-5 - 如何在 laravel 5.8 应用程序中扩展 laravel 包?
- javascript - 将导出的缓存放入模块中
- laravel - 如何查看 PHP 调试栏?(现在仅在错误 404 时显示)