таймер для обратного отчёта

Простой таймер обратного отчёта на JavaScript

Содержимое:

Привет! Сегодня мы рассмотрим создание простого таймера обратного отчёта на JavaScript. Данный счётчик, будет отсчитывать время до указанного числа. Для создания такого таймера вам нужны знания в HTML, CSS, JavaScript и немного PHP если вы планируете добавлять информацию о дате из БД.

Код счётчика был написан не мной, я только немного отредактировал его под себя. К сожалению я не помню, сайт на котором я его нашёл. Если ты являешься автором, то напиши мне и я укажу ссылку на оригинал.

Дней
:
Часов
:
Минут
:
Секунд

HTML

Главный элемент #countdown, в него записываем блоки для указания чисел даты. Атрибуты типа data, которые я создал для главного контейнера, я использую для передачи в них даты из админки.

<div id="countdown" class="countdown" data-day="22" data-month="12" data-year="2021">
        <div class="countdown-number">
            <span class="days countdown-time"></span>
            <span class="countdown-text">Дней</span>
        </div>
        <div class="dotBlockTimer">:</div>
        <div class="countdown-number">
            <span class="hours countdown-time"></span>
            <span class="countdown-text">Часов</span>
        </div>
        <div class="dotBlockTimer">:</div>
        <div class="countdown-number">
            <span class="minutes countdown-time"></span>
            <span class="countdown-text">Минут</span>
        </div>
        <div class="dotBlockTimer">:</div>
        <div class="countdown-number">
            <span class="seconds countdown-time"></span>
            <span class="countdown-text">Секунд</span>
        </div>
</div>

CSS

#countdown {
    display: flex;
    column-gap: 10px;
    bottom: 0;
    right: 0;
    margin: 20px;
    align-items: center;
    justify-content: center;
}
.countdown-title {
    color: #396;
    font-weight: 100;
    font-size: 40px;
    margin: 40px 0px 20px;
}
.countdown {
    font-family: sans-serif;
    color: #fff;
    display: inline-block;
    font-weight: 100;
    text-align: center;
    font-size: 30px;
}
.countdown-number {
    width: 80px;
    padding: 10px;
    border-radius: 10px;
    background: rgba(0,0,0,0.5);
    display: inline-block;
    width: 80px;
    border: 1px solid #fff;
}
.countdown-time {
    padding: 0;
    display: inline-block;
    font-size: 40px;
}
.countdown-text {
    display: block;
    padding-top: 5px;
    font-size: 13px;
}

JavaScript

В JavaScript создаём 2 функции. Первая, функция getTimeRemaining высчитывает разницу между текущей датой и конечной, после чего собирает объект из элементов даты.

Вторая - initializeClock, распределяем полученные данные по соответствующим элементам счётчика.

/* функция которая собирает массив из значений даты */
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);
}

/* получение данных о времени */
let day = document.querySelector("#countdown").getAttribute("data-day")
let month = document.querySelector("#countdown").getAttribute("data-month")
let year = document.querySelector("#countdown").getAttribute("data-year")



let  deadline = new Date(Date.parse(new Date(year, month, day, 0, 0, 0, 0))); 

initializeClock('countdown', deadline);
На этом всё!
Больше интересных статей в нашей группе - https://vk.com/progtime
Вы так же можете разместить свой вопрос на нашем форуме, где другие программисты смогут вам помочь в решение вашей задачи - https://vk.com/prog_time
Так же прокачивайте свои навыки на нашем канале - https://www.youtube.com/c/ProgTime