我想创建倒数计时器
但我想从WordPress的自定义字段中获取日期。
我想在ID为COUNTDWON的元素中显示倒数计时器

<p style="visibility: hidden; font-size: 0px;" id="time"><?php the_field('end_date');?></p>
<p id="countdown""></p>


我想使用此脚本(下)
我的问题是:如何从元素中获取日期
我不想每次都将日期手动添加到脚本中。
有什么办法吗?

var countDownDate = new Date("Sep 5, 2018 15:37:25").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);


在我尝试了这个答案之后:

// Fetch here
var dateTime = document.getElementById("time").innerHTML;

// Use it here
var countDownDate = new Date(dateTime).getTime();

// .... rest of the code


它仅适用于第一个字段,以下屏幕截图:
screenshot

最佳答案

如果PHP提供的日期格式相同,则可以使用document.getElementById()

// Fetch here
var dateTime = document.getElementById("time").innerHTML;

// Use it here
var countDownDate = new Date(dateTime).getTime();

// .... rest of the code


否则,您可能需要相应地设置dateTime变量的格式。

关于javascript - 如何通过ID获取日期,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/51190355/

10-09 20:06
查看更多