HTML - 圆环时钟

2023-07-13 14:06:13 浏览数 (2)

一款好看的时间时钟html代码,加在网站侧边栏也是非常好看,强力推荐!!

代码语言:javascript复制
            * {
                border: 0;
                box-sizing: border-box;
                margin: 0;
                padding: 0;
            }

            :root {
                --hue: 223;
                --bg: hsl(var(--hue), 10%, 90%);
                --fg: hsl(var(--hue), 10%, 10%);
                font-size: calc(16px   (24 - 16) * (100vw - 320px) / (1280 - 320));
            }

            body,
            button {
                color: #fff;
                font: 1em/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
            }

            body {
                background-color: #1F1F1F;
                height: 100vh;
                display: grid;
                place-items: center;
            }

            .progress-clock {
                display: grid;
                justify-content: center;
                align-content: center;
                position: relative;
                text-align: center;
                width: 16em;
                height: 16em;
            }

            .progress-clock__time-date,
            .progress-clock__time-digit,
            .progress-clock__time-colon,
            .progress-clock__time-ampm {
                transition: color 0.2s linear;
                -webkit-user-select: none;
                -moz-user-select: none;
                user-select: none;
            }

            .progress-clock__time-date,
            .progress-clock__time-digit {
                background: transparent;
            }

            .progress-clock__time-date,
            .progress-clock__time-ampm {
                grid-column: 1 / 6;
            }

            .progress-clock__time-date {
                font-size: 0.75em;
                line-height: 1.33;
            }

            .progress-clock__time-digit,
            .progress-clock__time-colon {
                font-size: 2em;
                font-weight: 400;
                grid-row: 2;
            }

            .progress-clock__time-colon {
                line-height: 1.275;
            }

            .progress-clock__time-ampm {
                cursor: default;
                grid-row: 3;
            }

            .progress-clock__rings {
                display: block;
                position: absolute;
                top: 0;
                left: 0;
                width: 100%;
                height: 100%;
                z-index: -1;
            }

            .progress-clock__ring {
                opacity: 0.1;
            }

            .progress-clock__ring-fill {
                transition:
                    opacity 0s 0.3s linear,
                    stroke-dashoffset 0.3s ease-in-out;
            }

            .progress-clock__ring-fill--360 {
                opacity: 0;
                stroke-dashoffset: 0;
                transition-duration: 0.3s;
            }

            [data-group]:focus {
                outline: transparent;
            }

            [data-units] {
                transition: opacity 0.2s linear;
            }

            [data-group="d"]:focus,
            [data-group="d"]:hover {
                color: hsl(333, 90%, 55%);
            }

            [data-group="h"]:focus,
            [data-group="h"]:hover {
                color: hsl(33, 90%, 55%);
            }

            [data-group="m"]:focus,
            [data-group="m"]:hover {
                color: hsl(213, 90%, 55%);
            }

            [data-group="s"]:focus,
            [data-group="s"]:hover {
                color: hsl(273, 90%, 55%);
            }

            [data-group]:focus~.progress-clock__rings [data-units],
            [data-group]:hover~.progress-clock__rings [data-units] {
                opacity: 0.2;
            }

            [data-group="d"]:focus~.progress-clock__rings [data-units="d"],
            [data-group="d"]:hover~.progress-clock__rings [data-units="d"],
            [data-group="h"]:focus~.progress-clock__rings [data-units="h"],
            [data-group="h"]:hover~.progress-clock__rings [data-units="h"],
            [data-group="m"]:focus~.progress-clock__rings [data-units="m"],
            [data-group="m"]:hover~.progress-clock__rings [data-units="m"],
            [data-group="s"]:focus~.progress-clock__rings [data-units="s"],
            [data-group="s"]:hover~.progress-clock__rings [data-units="s"] {
                opacity: 1;
            }

            /* Dark theme */
            @media (prefers-color-scheme: dark) {
                :root {
                    --bg: hsl(var(--hue), 10%, 10%);
                    --fg: hsl(var(--hue), 10%, 90%);
                }

                .progress-clock__ring {
                    opacity: 0.2;
                }
            }
        
    
    
        
            
                Sunday

                January
                1
            
            12:00:00
            AM
            
                
                    
                        
                        
                    
                    
                        
                        
                    
                    
                        
                        
                    
                    
                        
                        
                    
                
                
                
                    
                    
                
                
                
                    
                    
                
                
                
                    
                    
                
                
                
                    
                    
                
            
        
    
    
        window.addEventListener("DOMContentLoaded", () => {
            const clock = new ProgressClock("#clock");
        });

        class ProgressClock {
            constructor(qs) {
                this.el = document.querySelector(qs);
                this.time = 0;
                this.updateTimeout = null;
                this.ringTimeouts = [];
                this.update();
            }
            getDayOfWeek(day) {
                switch (day) {
                    case 1:
                        return "Monday";
                    case 2:
                        return "Tuesday";
                    case 3:
                        return "Wednesday";
                    case 4:
                        return "Thursday";
                    case 5:
                        return "Friday";
                    case 6:
                        return "Saturday";
                    default:
                        return "Sunday";
                }
            }
            getMonthInfo(mo, yr) {
                switch (mo) {
                    case 1:
                        return {
                            name: "February", days: yr % 4 === 0 ? 29 : 28
                        };
                    case 2:
                        return {
                            name: "March", days: 31
                        };
                    case 3:
                        return {
                            name: "April", days: 30
                        };
                    case 4:
                        return {
                            name: "May", days: 31
                        };
                    case 5:
                        return {
                            name: "June", days: 30
                        };
                    case 6:
                        return {
                            name: "July", days: 31
                        };
                    case 7:
                        return {
                            name: "August", days: 31
                        };
                    case 8:
                        return {
                            name: "September", days: 30
                        };
                    case 9:
                        return {
                            name: "October", days: 31
                        };
                    case 10:
                        return {
                            name: "November", days: 30
                        };
                    case 11:
                        return {
                            name: "December", days: 31
                        };
                    default:
                        return {
                            name: "January", days: 31
                        };
                }
            }
            update() {
                this.time = new Date();

                if (this.el) {
                    // date and time
                    const dayOfWeek = this.time.getDay();
                    const year = this.time.getFullYear();
                    const month = this.time.getMonth();
                    const day = this.time.getDate();
                    const hr = this.time.getHours();
                    const min = this.time.getMinutes();
                    const sec = this.time.getSeconds();
                    const dayOfWeekName = this.getDayOfWeek(dayOfWeek);
                    const monthInfo = this.getMonthInfo(month, year);
                    const m_progress = sec / 60;
                    const h_progress = (min   m_progress) / 60;
                    const d_progress = (hr   h_progress) / 24;
                    const mo_progress = ((day - 1)   d_progress) / monthInfo.days;
                    const units = [{
                            label: "w",
                            value: dayOfWeekName
                        },
                        {
                            label: "mo",
                            value: monthInfo.name,
                            progress: mo_progress
                        },
                        {
                            label: "d",
                            value: day,
                            progress: d_progress
                        },
                        {
                            label: "h",
                            value: hr > 12 ? hr - 12 : hr,
                            progress: h_progress
                        },
                        {
                            label: "m",
                            value: min < 10 ? "0"   min : min,
                            progress: m_progress
                        },
                        {
                            label: "s",
                            value: sec < 10 ? "0"   sec : sec
                        },
                        {
                            label: "ap",
                            value: hr > 12 ? "PM" : "AM"
                        }
                    ];

                    // flush out the timeouts
                    this.ringTimeouts.forEach(t => {
                        clearTimeout(t);
                    });
                    this.ringTimeouts = [];

                    // update the display
                    units.forEach(u => {
                        // rings
                        const ring = this.el.querySelector(`[data-ring="${u.label}"]`);

                        if (ring) {
                            const strokeDashArray = ring.getAttribute("stroke-dasharray");
                            const fill360 = "progress-clock__ring-fill--360";

                            if (strokeDashArray) {
                                // calculate the stroke
                                const circumference =  strokeDashArray.split(" ")[0];
                                const strokeDashOffsetPct = 1 - u.progress;

                                ring.setAttribute(
                                    "stroke-dashoffset",
                                    strokeDashOffsetPct * circumference
                                );

                                // add the fade-out transition, then remove it
                                if (strokeDashOffsetPct === 1) {
                                    ring.classList.add(fill360);

                                    this.ringTimeouts.push(
                                        setTimeout(() => {
                                            ring.classList.remove(fill360);
                                        }, 600)
                                    );
                                }
                            }
                        }

                        // digits
                        const unit = this.el.querySelector(`[data-unit="${u.label}"]`);

                        if (unit)
                            unit.innerText = u.value;
                    });
                }

                clearTimeout(this.updateTimeout);
                this.updateTimeout = setTimeout(this.update.bind(this), 1e3);
            }
        }

0 人点赞