Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #1 (permalink)  
Старый 29.07.2017, 08:48
Кандидат Javascript-наук
Отправить личное сообщение для biryukovm Посмотреть профиль Найти все сообщения от biryukovm
 
Регистрация: 13.12.2013
Сообщений: 110

Универсальный таймер
Привет всем.


Я когда то довным довно искал таймер который нашел и все круто было до тех пор пока не задался вопросом нескольких таймеров на странице

Есть рабочий образец вот
<div id="clockdiv" class="timmer_style">
  <div><span class="days"></span><div class="smalltext">Дней</div></div>
  <div><span class="hours"></span><div class="smalltext">Часов</div></div>
  <div><span class="minutes"></span><div class="smalltext">Минут</div></div>
  <div><span class="seconds"></span><div class="smalltext">Секунд</div></div>
</div>

<script type="text/javascript">
function getTimeRemaining(endtime) {
  var t = Date.parse(endtime) - Date.parse(new Date());
  var seconds = Math.floor((t / 1000) % 60);
  var minutes = Math.floor((t / 1000 / 60) % 60);
  var hours = Math.floor((t / (1000 * 60 * 60)) % 24);
  var days = Math.floor(t / (1000 * 60 * 60 * 24));
  return {
    'total': t,
    'days': days,
    'hours': hours,
    'minutes': minutes,
    'seconds': seconds
  };
}

function initializeClock(id, endtime) {
  var clock = document.getElementById(id);
  var daysSpan = clock.querySelector('.days');
  var hoursSpan = clock.querySelector('.hours');
  var minutesSpan = clock.querySelector('.minutes');
  var secondsSpan = clock.querySelector('.seconds');

  function updateClock() {
    var t = getTimeRemaining(endtime);
    daysSpan.innerHTML = t.days;
    hoursSpan.innerHTML = ('0' + t.hours).slice(-2);
    minutesSpan.innerHTML = ('0' + t.minutes).slice(-2);
    secondsSpan.innerHTML = ('0' + t.seconds).slice(-2);
    if (t.total <= 0) {clearInterval(timeinterval);}
  }
  updateClock();
  var timeinterval = setInterval(updateClock, 1000);
}

var deadline = new Date(Date.parse(new Date()) + 900 * 1000);



initializeClock('clockdiv', deadline);
</script>



И теперь встает задача как создать кучу таймеров на одно странице и оповещать сервер о завершении времени одного из таймеров.

Я это вижу так таймеры загнать в значение class
В главном class таймера передать 2 дополнительных значения (Дата и ключь)
Когда скрипт понимает что время таймера закончилось он уведомляет сервер через Ajax какой таймер завершил работу чтобы после принять решения перезаписи HTML таймера или убрать его


Что можете посоветовать ?
А лучши рабочий образец
Ответить с цитированием
  #2 (permalink)  
Старый 31.07.2017, 10:41
Профессор
Отправить личное сообщение для Dilettante_Pro Посмотреть профиль Найти все сообщения от Dilettante_Pro
 
Регистрация: 27.11.2015
Сообщений: 2,899

2 таймера
<style>
.timmer_style {
    float:left; 
    border:1px solid black;
}
</style>
<div id="clockdiv" class="timmer_style">
  <div><span class="days"></span><div class="smalltext">Дней</div></div>
  <div><span class="hours"></span><div class="smalltext">Часов</div></div>
  <div><span class="minutes"></span><div class="smalltext">Минут</div></div>
  <div><span class="seconds"></span><div class="smalltext">Секунд</div></div>
</div>
<div id="clockdiv1" class="timmer_style">
  <div><span class="days"></span><div class="smalltext">Дней</div></div>
  <div><span class="hours"></span><div class="smalltext">Часов</div></div>
  <div><span class="minutes"></span><div class="smalltext">Минут</div></div>
  <div><span class="seconds"></span><div class="smalltext">Секунд</div></div>
</div>

<script type="text/javascript">
function getTimeRemaining(endtime) {
  var t = Date.parse(endtime) - Date.parse(new Date());
  var seconds = Math.floor((t / 1000) % 60);
  var minutes = Math.floor((t / 1000 / 60) % 60);
  var hours = Math.floor((t / (1000 * 60 * 60)) % 24);
  var days = Math.floor(t / (1000 * 60 * 60 * 24));
  return {
    'total': t,
    'days': days,
    'hours': hours,
    'minutes': minutes,
    'seconds': seconds
  };
}

function initializeClock(id, endtime) {
  var clock = document.getElementById(id);
  var daysSpan = clock.querySelector('.days');
  var hoursSpan = clock.querySelector('.hours');
  var minutesSpan = clock.querySelector('.minutes');
  var secondsSpan = clock.querySelector('.seconds');

  function updateClock() {
    var t = getTimeRemaining(endtime);
    daysSpan.innerHTML = t.days;
    hoursSpan.innerHTML = ('0' + t.hours).slice(-2);
    minutesSpan.innerHTML = ('0' + t.minutes).slice(-2);
    secondsSpan.innerHTML = ('0' + t.seconds).slice(-2);
    if (t.total <= 0) {clearInterval(timeinterval);}
  }
  updateClock();
  var timeinterval = setInterval(updateClock, 1000);
}

var deadline = new Date(Date.parse(new Date()) + 900 * 1000);

initializeClock('clockdiv', deadline);

initializeClock('clockdiv1', new Date(Date.parse(new Date()) + 100 * 1000));
</script>

Последний раз редактировалось Dilettante_Pro, 31.07.2017 в 11:22.
Ответить с цитированием
  #3 (permalink)  
Старый 08.08.2017, 09:41
Кандидат Javascript-наук
Отправить личное сообщение для biryukovm Посмотреть профиль Найти все сообщения от biryukovm
 
Регистрация: 13.12.2013
Сообщений: 110

Сообщение от Dilettante_Pro Посмотреть сообщение
2 таймера
<style>
.timmer_style {
    float:left; 
    border:1px solid black;
}
</style>
<div id="clockdiv" class="timmer_style">
  <div><span class="days"></span><div class="smalltext">Дней</div></div>
  <div><span class="hours"></span><div class="smalltext">Часов</div></div>
  <div><span class="minutes"></span><div class="smalltext">Минут</div></div>
  <div><span class="seconds"></span><div class="smalltext">Секунд</div></div>
</div>
<div id="clockdiv1" class="timmer_style">
  <div><span class="days"></span><div class="smalltext">Дней</div></div>
  <div><span class="hours"></span><div class="smalltext">Часов</div></div>
  <div><span class="minutes"></span><div class="smalltext">Минут</div></div>
  <div><span class="seconds"></span><div class="smalltext">Секунд</div></div>
</div>

<script type="text/javascript">
function getTimeRemaining(endtime) {
  var t = Date.parse(endtime) - Date.parse(new Date());
  var seconds = Math.floor((t / 1000) % 60);
  var minutes = Math.floor((t / 1000 / 60) % 60);
  var hours = Math.floor((t / (1000 * 60 * 60)) % 24);
  var days = Math.floor(t / (1000 * 60 * 60 * 24));
  return {
    'total': t,
    'days': days,
    'hours': hours,
    'minutes': minutes,
    'seconds': seconds
  };
}

function initializeClock(id, endtime) {
  var clock = document.getElementById(id);
  var daysSpan = clock.querySelector('.days');
  var hoursSpan = clock.querySelector('.hours');
  var minutesSpan = clock.querySelector('.minutes');
  var secondsSpan = clock.querySelector('.seconds');

  function updateClock() {
    var t = getTimeRemaining(endtime);
    daysSpan.innerHTML = t.days;
    hoursSpan.innerHTML = ('0' + t.hours).slice(-2);
    minutesSpan.innerHTML = ('0' + t.minutes).slice(-2);
    secondsSpan.innerHTML = ('0' + t.seconds).slice(-2);
    if (t.total <= 0) {clearInterval(timeinterval);}
  }
  updateClock();
  var timeinterval = setInterval(updateClock, 1000);
}

var deadline = new Date(Date.parse(new Date()) + 900 * 1000);

initializeClock('clockdiv', deadline);

initializeClock('clockdiv1', new Date(Date.parse(new Date()) + 100 * 1000));
</script>


А как сделат так чтобы я не так указывал
initializeClock('clockdiv1', new Date(Date.parse(new Date()) + 100 * 1000));



А указал Class и у него предположим был пораметр дата и от него понималось что считывать

Это выгледит типа
<div id="clockdiv" class="timmer_style" data="900">
Ответить с цитированием
  #4 (permalink)  
Старый 08.08.2017, 10:43
Профессор
Отправить личное сообщение для Dilettante_Pro Посмотреть профиль Найти все сообщения от Dilettante_Pro
 
Регистрация: 27.11.2015
Сообщений: 2,899

<style>
.timer_style {
    float:left; 
    border:1px solid black;
}
</style>
<div id="clockdiv" class="timer_style" data-stop="900">
  <div><span class="days"></span><div class="smalltext">Дней</div></div>
  <div><span class="hours"></span><div class="smalltext">Часов</div></div>
  <div><span class="minutes"></span><div class="smalltext">Минут</div></div>
  <div><span class="seconds"></span><div class="smalltext">Секунд</div></div>
</div>
<div id="clockdiv1" class="timer_style" data-stop="100">
  <div><span class="days"></span><div class="smalltext">Дней</div></div>
  <div><span class="hours"></span><div class="smalltext">Часов</div></div>
  <div><span class="minutes"></span><div class="smalltext">Минут</div></div>
  <div><span class="seconds"></span><div class="smalltext">Секунд</div></div>
</div>

<script type="text/javascript">
function getTimeRemaining(endtime) {
  var t = Date.parse(endtime) - Date.parse(new Date());
  var seconds = Math.floor((t / 1000) % 60);
  var minutes = Math.floor((t / 1000 / 60) % 60);
  var hours = Math.floor((t / (1000 * 60 * 60)) % 24);
  var days = Math.floor(t / (1000 * 60 * 60 * 24));
  return {
    'total': t,
    'days': days,
    'hours': hours,
    'minutes': minutes,
    'seconds': seconds
  };
}

function initializeClock(id, endtime) {
  var clock = document.getElementById(id);
  var daysSpan = clock.querySelector('.days');
  var hoursSpan = clock.querySelector('.hours');
  var minutesSpan = clock.querySelector('.minutes');
  var secondsSpan = clock.querySelector('.seconds');

  function updateClock() {
    var t = getTimeRemaining(endtime);
    daysSpan.innerHTML = t.days;
    hoursSpan.innerHTML = ('0' + t.hours).slice(-2);
    minutesSpan.innerHTML = ('0' + t.minutes).slice(-2);
    secondsSpan.innerHTML = ('0' + t.seconds).slice(-2);
    if (t.total <= 0) {clearInterval(timeinterval);}
  }
  updateClock();
  var timeinterval = setInterval(updateClock, 1000);
};

var clocks = document.querySelectorAll('.timer_style');

clocks.forEach(function (elem) {
   initializeClock(elem.id , new Date(Date.parse(new Date()) + elem.getAttribute('data-stop') * 1000));
});

</script>
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Индивидуальный таймер обратного отсчета времени с редиректом pozitiv4ek Работа 2 11.12.2016 13:42
Таймер на вкладках в Хроме. YNA Opera, Safari и др. 1 28.01.2016 02:43
помогите чтобы таймер тикал Руслан904322 Общие вопросы Javascript 1 22.02.2015 12:43
Таймер до требуемой даты в цикле Drugpunker Events/DOM/Window 22 21.03.2014 08:52
Обновляемый таймер на javascript smillyhamster Общие вопросы Javascript 1 31.12.2013 10:30