设置倒数计时器的开始和结束日期? (使用Meteor.js)

时间:2016-01-31 20:04:16

标签: javascript meteor

现在我有一个倒数计时器,从当前系统时间倒计时到结束时间,但我希望能够创建一个开始时间,我不知道该怎么做。这是我现在的javascript:

if (Meteor.isClient) {
var timeinterval;

Meteor.startup(function () {
var starttime = 'February 19 2016 22:00:00 UTC-0600'
var endtime = 'February 21 2016 10:00:00 UTC-0600';
timeinterval = setInterval(function () {
  Meteor.call("getCurrentTime", function (error, result) {
    Session.set("time", result);
    var t = getTimeRemaining(endtime);
    Session.set("t", t);
  });
}, 1000);
});

function getTimeRemaining(endtime){
var t = Date.parse(endtime) - starttime;
var seconds = ("0" + Math.floor( (t/1000) % 60 )).slice(-2);
var minutes = ("0" + Math.floor( (t/1000/60) % 60 )).slice(-2);
var hours = ("0" + Math.floor( (t/(1000*60*60)) % 24 )).slice(-2);
var days = Math.floor( t/(1000*60*60*24) );

console.log(t)
if(t <= 0)
  clearInterval(timeinterval);

return {
  'total': t,
  'days': days,
  'hours': hours,
  'minutes': minutes,
  'seconds': seconds
};

}

Template.countdown.helpers({
t: function () {
  return Session.get("t");
}
});

Template.body.helpers({
ended:function () {
  console.log(Session.get("t").total <= 0);
  return Session.get("t").total <= 0;
}
});
}

if (Meteor.isServer) {
 Meteor.startup(function () {

});

Meteor.methods({
 'getCurrentTime': function (){
   return Date.parse(new Date());
 }
 });
 }

我真的不确定从哪里开始,因为我没有任何javascript经验。任何帮助都会很棒。谢谢!

2 个答案:

答案 0 :(得分:0)

如果您正在谈论创建自XYZ日期以来的时间&#39;计时器,我使用此套餐:https://github.com/copleykj/meteor-livestamp

这将为您提供一些功能,可以说明事情发生后的持续时间(例如3分钟前),就像Facebook评论一样。

答案 1 :(得分:0)

如果我理解正确的话,

听起来对你来说,你想要倒计时开始(如果开始时间比现在晚),要么倒计时结束(如果它已经开始)。

或许你只是想不显示计时器,除非它已经开始,你的问题不清楚。

无论哪种方式,只需修改你的getTimeRemaining函数来获取start time参数,并检查if now是否小于start,如果是,则计算start而不是end。

after_validation :geocode, if: ->(obj){ obj.address.present? and obj.address_changed? }

希望有所帮助:)