用圆形进度条告诉时间,将鼠标悬停或聚集在日期、小时、分钟和秒上单独查看他们!

<!-- saved from url=(0043)https://nuoyo.cn --><html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"><title>clock</title><style>* {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;*/color: #888a8f;/*color: #000;*/font: 1em/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;}body {/*background-color: #1F1F1F;*//*background-color: #FFFFFF;*/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;}}</style><style id="translate-plugin-css_1694057326023" type="text/css">@charset "utf-8";:focus {outline:none;}.jsfyg {position:relative; display:flex;flex-direction: column;height:100%;}.jsfyg h5 {display: flex;width: 100%;justify-content: space-between;align-items: center;}.jsfyg h5 span i {width:20px; height:20px; background:url() no-repeat -120px 0px; display: inline-block; vertical-align:middle; margin:0px 5px;}.jsfyg h5 em ,.webgcopy,.webbcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle; margin-right: 10px;}.jsfyg h5 em:hover { background-position:-100px -20px; cursor:pointer;}.jsfyg h5 span i.bd { background-position:-120px -22px; width:60px;}.jsfyg .baidu {flex:1; overflow-y:auto; padding:5px 10px; line-height:26px;word-wrap:break-word;word-break:break-all;}.jsfyg .baidu::-webkit-scrollbar {width:6px; background-color:#fff;}.jsfyg .baidu::-webkit-scrollbar-track {border-radius:10px;}.jsfyg .baidu::-webkit-scrollbar-thumb {border-radius:10px;background:#d7d7d7;}.jsfytxt { position:relative;}.jsfyloading {position:absolute;top: 45%;left: 50%;color: #121212;font-size: 4px;width: 1em;height: 1em;border-radius: 50%;text-indent: -9999em;animation: load4 1.3s infinite linear;transform: translateX(-50%);}@keyframes load4 {0%,100% {box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0;}12.5% {box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;}25% {box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em;}37.5% {box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 0, 2em 2em 0 0.2em, 0 3em 0 0em, -2em 2em 0 -1em, -3em 0em 0 -1em, -2em -2em 0 -1em;}50% {box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0em, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0em 0 -1em, -2em -2em 0 -1em;}62.5% {box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em;}75% {box-shadow: 0em -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0.2em, -2em -2em 0 0;}87.5% {box-shadow: 0em -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0, -2em -2em 0 0.2em;}}@media (prefers-color-scheme: dark) {.jsfyloading{color: #9b9797 !important;}}.jsfyloading img{display:none;}.jsfytxtlayer { display:none; font-size:14px; color:#333;position:absolute; left:50%; top:30px; margin-left:-100px; background:#fff; width:340px; height:260px; padding:5px;z-index:200000001; border:1px solid #cfcfcf;}.jsfytxtlayer .jsfyg h5 { border-bottom:none; margin:10px auto 5px auto;}.jsfycorner { width: 0px;height: 0px;border-width: 8px 8px;border-color: transparent transparent #fff;border-style: solid; position: absolute; top:-15px; left:28%; margin-left:-8px; z-index:100001;}.jsfycornerbg { width: 0px;height: 0px;border-width: 9px 9px;border-color: transparent transparent #cfcfcf;border-style: solid; position: absolute; top:-18px; left:28%; margin-left:-9px; z-index:100001;}.jsfytxtlayerbox {height:250px; padding:5px;}.jsfytxttotal {position: absolute;right: 10px;bottom: 5px; color:#666;}.jsfyg h5 .webgcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle;}.no-events{pointer-events: none !important;}</style></head><body style=""><!-- 禁用右键开始 --><script type="text/Javascript">document.oncontextmenu = function(e) {return false;};document.onselectstart = function(e) {return false;};</script><!-- 禁用右键结束 --><div id="clock" class="progress-clock"><button class="progress-clock__time-date" data-group="d" type="button"><small data-unit="w">星期四</small><br><span data-unit="y">2023</span><span>年</span><span data-unit="mo">09月</span><span data-unit="d">07</span><span>日</span></button><button class="progress-clock__time-digit" data-unit="h" data-group="h" type="button">11</button><span class="progress-clock__time-colon">:</span><button class="progress-clock__time-digit" data-unit="m" data-group="m" type="button">28</button><span class="progress-clock__time-colon">:</span><button class="progress-clock__time-digit" data-unit="s" data-group="s" type="button">56</button><span class="progress-clock__time-ampm" data-unit="ap">AM</span><svg class="progress-clock__rings" width="256" height="256" viewBox="0 0 256 256"><defs><lineargradient id="pc-red" x1="1" y1="0.5" x2="0" y2="0.5"><stop offset="0%" stop-color="hsl(343,90%,55%)"></stop><stop offset="100%" stop-color="hsl(323,90%,55%)"></stop></lineargradient><lineargradient id="pc-yellow" x1="1" y1="0.5" x2="0" y2="0.5"><stop offset="0%" stop-color="hsl(43,90%,55%)"></stop><stop offset="100%" stop-color="hsl(23,90%,55%)"></stop></lineargradient><lineargradient id="pc-blue" x1="1" y1="0.5" x2="0" y2="0.5"><stop offset="0%" stop-color="hsl(223,90%,55%)"></stop><stop offset="100%" stop-color="hsl(203,90%,55%)"></stop></lineargradient><lineargradient id="pc-purple" x1="1" y1="0.5" x2="0" y2="0.5"><stop offset="0%" stop-color="hsl(283,90%,55%)"></stop><stop offset="100%" stop-color="hsl(263,90%,55%)"></stop></lineargradient></defs><!-- Days of Month --><g data-units="d"><circle class="progress-clock__ring" cx="128" cy="128" r="74" fill="none" opacity="0.1" stroke="url(#pc-red)" stroke-width="12"></circle><circle class="progress-clock__ring-fill" data-ring="mo" cx="128" cy="128" r="74" fill="none" stroke="url(#pc-red)" stroke-width="12" stroke-dasharray="465 465" stroke-dashoffset="364.5843981481482" stroke-linecap="round" transform="rotate(-90,128,128)"></circle></g><!-- Hours of Day --><g data-units="h"><circle class="progress-clock__ring" cx="128" cy="128" r="90" fill="none" opacity="0.1" stroke="url(#pc-yellow)" stroke-width="12"></circle><circle class="progress-clock__ring-fill" data-ring="d" cx="128" cy="128" r="90" fill="none" stroke="url(#pc-yellow)" stroke-width="12" stroke-dasharray="565.5 565.5" stroke-dashoffset="294.95013888888883" stroke-linecap="round" transform="rotate(-90,128,128)"></circle></g><!-- Minutes of Hour --><g data-units="m"><circle class="progress-clock__ring" cx="128" cy="128" r="106" fill="none" opacity="0.1" stroke="url(#pc-blue)" stroke-width="12"></circle><circle class="progress-clock__ring-fill" data-ring="h" cx="128" cy="128" r="106" fill="none" stroke="url(#pc-blue)" stroke-width="12" stroke-dasharray="666 666" stroke-dashoffset="344.84" stroke-linecap="round" transform="rotate(-90,128,128)"></circle></g><!-- Seconds of Minute --><g data-units="s"><circle class="progress-clock__ring" cx="128" cy="128" r="122" fill="none" opacity="0.1" stroke="url(#pc-purple)" stroke-width="12"></circle><circle class="progress-clock__ring-fill" data-ring="m" cx="128" cy="128" r="122" fill="none" stroke="url(#pc-purple)" stroke-width="12" stroke-dasharray="766.5 766.5" stroke-dashoffset="51.09999999999999" stroke-linecap="round" transform="rotate(-90,128,128)"></circle></g></svg></div><script type="text/javascript">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 "星期一";case 2:return "星期二";case 3:return "星期三";case 4:return "星期四";case 5:return "星期五";case 6:return "星期六";default:return "星期日";}}getMonthInfo(mo, yr) {switch (mo) {case 1:return {name: "02月",days: yr % 4 === 0 ? 29 : 28};case 2:return {name: "03月",days: 31};case 3:return {name: "04月",days: 30};case 4:return {name: "05月",days: 31};case 5:return {name: "06月",days: 30};case 6:return {name: "07月",days: 31};case 7:return {name: "08月",days: 31};case 8:return {name: "09月",days: 30};case 9:return {name: "10月",days: 31};case 10:return {name: "11月",days: 30};case 11:return {name: "12月",days: 31};default:return {name: "01月",days: 31};}}update() {this.time = new Date();if (this.el) {// date and timeconst 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: "y",value: year}, {label: "w",value: dayOfWeekName}, {label: "mo",value: monthInfo.name,progress: mo_progress}, {label: "d",value: day < 10 ? "0" + day : day,progress: d_progress}, {label: "h",value: hr > 12 ? ((hr - 12) < 10 ? "0" + (hr - 12) : (hr - 12)) : (hr < 10 ? "0" + hr : 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 timeoutsthis.ringTimeouts.forEach(t=>{clearTimeout(t);});this.ringTimeouts = [];// update the displayunits.forEach(u=>{// ringsconst 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 strokeconst circumference = +strokeDashArray.split(" ")[0];const strokeDashOffsetPct = 1 - u.progress;ring.setAttribute("stroke-dashoffset", strokeDashOffsetPct * circumference);// add the fade-out transition, then remove itif (strokeDashOffsetPct === 1) {ring.classList.add(fill360);this.ringTimeouts.push(setTimeout(()=>{ring.classList.remove(fill360);}, 600));}}}// digitsconst 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);}}</script></body></html><!-- saved from url=(0043)https://nuoyo.cn --> <html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>clock</title> <style> * { 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;*/ color: #888a8f; /*color: #000;*/ font: 1em/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; } body { /*background-color: #1F1F1F;*/ /*background-color: #FFFFFF;*/ 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; } } </style> <style id="translate-plugin-css_1694057326023" type="text/css">@charset "utf-8"; :focus {outline:none;} .jsfyg {position:relative; display:flex;flex-direction: column;height:100%;} .jsfyg h5 {display: flex;width: 100%;justify-content: space-between;align-items: center;} .jsfyg h5 span i {width:20px; height:20px; background:url() no-repeat -120px 0px; display: inline-block; vertical-align:middle; margin:0px 5px;} .jsfyg h5 em ,.webgcopy,.webbcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle; margin-right: 10px;} .jsfyg h5 em:hover { background-position:-100px -20px; cursor:pointer;} .jsfyg h5 span i.bd { background-position:-120px -22px; width:60px;} .jsfyg .baidu {flex:1; overflow-y:auto; padding:5px 10px; line-height:26px;word-wrap:break-word;word-break:break-all;} .jsfyg .baidu::-webkit-scrollbar {width:6px; background-color:#fff;} .jsfyg .baidu::-webkit-scrollbar-track {border-radius:10px;} .jsfyg .baidu::-webkit-scrollbar-thumb {border-radius:10px;background:#d7d7d7;} .jsfytxt { position:relative;} .jsfyloading { position:absolute; top: 45%; left: 50%; color: #121212; font-size: 4px; width: 1em; height: 1em; border-radius: 50%; text-indent: -9999em; animation: load4 1.3s infinite linear; transform: translateX(-50%); } @keyframes load4 { 0%, 100% { box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0; } 12.5% { box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em; } 25% { box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em; } 37.5% { box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 0, 2em 2em 0 0.2em, 0 3em 0 0em, -2em 2em 0 -1em, -3em 0em 0 -1em, -2em -2em 0 -1em; } 50% { box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0em, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0em 0 -1em, -2em -2em 0 -1em; } 62.5% { box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em; } 75% { box-shadow: 0em -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0.2em, -2em -2em 0 0; } 87.5% { box-shadow: 0em -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0, -2em -2em 0 0.2em; } } @media (prefers-color-scheme: dark) { .jsfyloading{ color: #9b9797 !important; } } .jsfyloading img{ display:none; } .jsfytxtlayer { display:none; font-size:14px; color:#333;position:absolute; left:50%; top:30px; margin-left:-100px; background:#fff; width:340px; height:260px; padding:5px;z-index:200000001; border:1px solid #cfcfcf;} .jsfytxtlayer .jsfyg h5 { border-bottom:none; margin:10px auto 5px auto;} .jsfycorner { width: 0px;height: 0px;border-width: 8px 8px;border-color: transparent transparent #fff;border-style: solid; position: absolute; top:-15px; left:28%; margin-left:-8px; z-index:100001;} .jsfycornerbg { width: 0px;height: 0px;border-width: 9px 9px;border-color: transparent transparent #cfcfcf;border-style: solid; position: absolute; top:-18px; left:28%; margin-left:-9px; z-index:100001;} .jsfytxtlayerbox {height:250px; padding:5px;} .jsfytxttotal {position: absolute;right: 10px;bottom: 5px; color:#666;} .jsfyg h5 .webgcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle;} .no-events{pointer-events: none !important;} </style></head> <body style=""> <!-- 禁用右键开始 --> <script type="text/Javascript"> document.oncontextmenu = function(e) { return false; }; document.onselectstart = function(e) { return false; }; </script> <!-- 禁用右键结束 --> <div id="clock" class="progress-clock"> <button class="progress-clock__time-date" data-group="d" type="button"> <small data-unit="w">星期四</small> <br> <span data-unit="y">2023</span><span>年</span> <span data-unit="mo">09月</span> <span data-unit="d">07</span><span>日</span> </button> <button class="progress-clock__time-digit" data-unit="h" data-group="h" type="button">11</button> <span class="progress-clock__time-colon">:</span> <button class="progress-clock__time-digit" data-unit="m" data-group="m" type="button">28</button> <span class="progress-clock__time-colon">:</span> <button class="progress-clock__time-digit" data-unit="s" data-group="s" type="button">56</button> <span class="progress-clock__time-ampm" data-unit="ap">AM</span> <svg class="progress-clock__rings" width="256" height="256" viewBox="0 0 256 256"> <defs> <lineargradient id="pc-red" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(343,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(323,90%,55%)"></stop> </lineargradient> <lineargradient id="pc-yellow" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(43,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(23,90%,55%)"></stop> </lineargradient> <lineargradient id="pc-blue" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(223,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(203,90%,55%)"></stop> </lineargradient> <lineargradient id="pc-purple" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(283,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(263,90%,55%)"></stop> </lineargradient> </defs> <!-- Days of Month --> <g data-units="d"> <circle class="progress-clock__ring" cx="128" cy="128" r="74" fill="none" opacity="0.1" stroke="url(#pc-red)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="mo" cx="128" cy="128" r="74" fill="none" stroke="url(#pc-red)" stroke-width="12" stroke-dasharray="465 465" stroke-dashoffset="364.5843981481482" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> <!-- Hours of Day --> <g data-units="h"> <circle class="progress-clock__ring" cx="128" cy="128" r="90" fill="none" opacity="0.1" stroke="url(#pc-yellow)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="d" cx="128" cy="128" r="90" fill="none" stroke="url(#pc-yellow)" stroke-width="12" stroke-dasharray="565.5 565.5" stroke-dashoffset="294.95013888888883" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> <!-- Minutes of Hour --> <g data-units="m"> <circle class="progress-clock__ring" cx="128" cy="128" r="106" fill="none" opacity="0.1" stroke="url(#pc-blue)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="h" cx="128" cy="128" r="106" fill="none" stroke="url(#pc-blue)" stroke-width="12" stroke-dasharray="666 666" stroke-dashoffset="344.84" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> <!-- Seconds of Minute --> <g data-units="s"> <circle class="progress-clock__ring" cx="128" cy="128" r="122" fill="none" opacity="0.1" stroke="url(#pc-purple)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="m" cx="128" cy="128" r="122" fill="none" stroke="url(#pc-purple)" stroke-width="12" stroke-dasharray="766.5 766.5" stroke-dashoffset="51.09999999999999" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> </svg> </div> <script type="text/javascript"> 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 "星期一"; case 2: return "星期二"; case 3: return "星期三"; case 4: return "星期四"; case 5: return "星期五"; case 6: return "星期六"; default: return "星期日"; } } getMonthInfo(mo, yr) { switch (mo) { case 1: return { name: "02月", days: yr % 4 === 0 ? 29 : 28 }; case 2: return { name: "03月", days: 31 }; case 3: return { name: "04月", days: 30 }; case 4: return { name: "05月", days: 31 }; case 5: return { name: "06月", days: 30 }; case 6: return { name: "07月", days: 31 }; case 7: return { name: "08月", days: 31 }; case 8: return { name: "09月", days: 30 }; case 9: return { name: "10月", days: 31 }; case 10: return { name: "11月", days: 30 }; case 11: return { name: "12月", days: 31 }; default: return { name: "01月", 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: "y", value: year }, { label: "w", value: dayOfWeekName }, { label: "mo", value: monthInfo.name, progress: mo_progress }, { label: "d", value: day < 10 ? "0" + day : day, progress: d_progress }, { label: "h", value: hr > 12 ? ((hr - 12) < 10 ? "0" + (hr - 12) : (hr - 12)) : (hr < 10 ? "0" + hr : 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); } } </script> </body></html><!-- saved from url=(0043)https://nuoyo.cn --> <html><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>clock</title> <style> * { 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;*/ color: #888a8f; /*color: #000;*/ font: 1em/1.5 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif; } body { /*background-color: #1F1F1F;*/ /*background-color: #FFFFFF;*/ 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; } } </style> <style id="translate-plugin-css_1694057326023" type="text/css">@charset "utf-8"; :focus {outline:none;} .jsfyg {position:relative; display:flex;flex-direction: column;height:100%;} .jsfyg h5 {display: flex;width: 100%;justify-content: space-between;align-items: center;} .jsfyg h5 span i {width:20px; height:20px; background:url() no-repeat -120px 0px; display: inline-block; vertical-align:middle; margin:0px 5px;} .jsfyg h5 em ,.webgcopy,.webbcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle; margin-right: 10px;} .jsfyg h5 em:hover { background-position:-100px -20px; cursor:pointer;} .jsfyg h5 span i.bd { background-position:-120px -22px; width:60px;} .jsfyg .baidu {flex:1; overflow-y:auto; padding:5px 10px; line-height:26px;word-wrap:break-word;word-break:break-all;} .jsfyg .baidu::-webkit-scrollbar {width:6px; background-color:#fff;} .jsfyg .baidu::-webkit-scrollbar-track {border-radius:10px;} .jsfyg .baidu::-webkit-scrollbar-thumb {border-radius:10px;background:#d7d7d7;} .jsfytxt { position:relative;} .jsfyloading { position:absolute; top: 45%; left: 50%; color: #121212; font-size: 4px; width: 1em; height: 1em; border-radius: 50%; text-indent: -9999em; animation: load4 1.3s infinite linear; transform: translateX(-50%); } @keyframes load4 { 0%, 100% { box-shadow: 0 -3em 0 0.2em, 2em -2em 0 0em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 0; } 12.5% { box-shadow: 0 -3em 0 0, 2em -2em 0 0.2em, 3em 0 0 0, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em; } 25% { box-shadow: 0 -3em 0 -0.5em, 2em -2em 0 0, 3em 0 0 0.2em, 2em 2em 0 0, 0 3em 0 -1em, -2em 2em 0 -1em, -3em 0 0 -1em, -2em -2em 0 -1em; } 37.5% { box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 0, 2em 2em 0 0.2em, 0 3em 0 0em, -2em 2em 0 -1em, -3em 0em 0 -1em, -2em -2em 0 -1em; } 50% { box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 0em, 0 3em 0 0.2em, -2em 2em 0 0, -3em 0em 0 -1em, -2em -2em 0 -1em; } 62.5% { box-shadow: 0 -3em 0 -1em, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 0, -2em 2em 0 0.2em, -3em 0 0 0, -2em -2em 0 -1em; } 75% { box-shadow: 0em -3em 0 -1em, 2em -2em 0 -1em, 3em 0em 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0.2em, -2em -2em 0 0; } 87.5% { box-shadow: 0em -3em 0 0, 2em -2em 0 -1em, 3em 0 0 -1em, 2em 2em 0 -1em, 0 3em 0 -1em, -2em 2em 0 0, -3em 0em 0 0, -2em -2em 0 0.2em; } } @media (prefers-color-scheme: dark) { .jsfyloading{ color: #9b9797 !important; } } .jsfyloading img{ display:none; } .jsfytxtlayer { display:none; font-size:14px; color:#333;position:absolute; left:50%; top:30px; margin-left:-100px; background:#fff; width:340px; height:260px; padding:5px;z-index:200000001; border:1px solid #cfcfcf;} .jsfytxtlayer .jsfyg h5 { border-bottom:none; margin:10px auto 5px auto;} .jsfycorner { width: 0px;height: 0px;border-width: 8px 8px;border-color: transparent transparent #fff;border-style: solid; position: absolute; top:-15px; left:28%; margin-left:-8px; z-index:100001;} .jsfycornerbg { width: 0px;height: 0px;border-width: 9px 9px;border-color: transparent transparent #cfcfcf;border-style: solid; position: absolute; top:-18px; left:28%; margin-left:-9px; z-index:100001;} .jsfytxtlayerbox {height:250px; padding:5px;} .jsfytxttotal {position: absolute;right: 10px;bottom: 5px; color:#666;} .jsfyg h5 .webgcopy{ float:right;width:20px; height:20px; background:url() no-repeat -100px 0px; display: inline-block; vertical-align:middle;} .no-events{pointer-events: none !important;} </style></head> <body style=""> <!-- 禁用右键开始 --> <script type="text/Javascript"> document.oncontextmenu = function(e) { return false; }; document.onselectstart = function(e) { return false; }; </script> <!-- 禁用右键结束 --> <div id="clock" class="progress-clock"> <button class="progress-clock__time-date" data-group="d" type="button"> <small data-unit="w">星期四</small> <br> <span data-unit="y">2023</span><span>年</span> <span data-unit="mo">09月</span> <span data-unit="d">07</span><span>日</span> </button> <button class="progress-clock__time-digit" data-unit="h" data-group="h" type="button">11</button> <span class="progress-clock__time-colon">:</span> <button class="progress-clock__time-digit" data-unit="m" data-group="m" type="button">28</button> <span class="progress-clock__time-colon">:</span> <button class="progress-clock__time-digit" data-unit="s" data-group="s" type="button">56</button> <span class="progress-clock__time-ampm" data-unit="ap">AM</span> <svg class="progress-clock__rings" width="256" height="256" viewBox="0 0 256 256"> <defs> <lineargradient id="pc-red" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(343,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(323,90%,55%)"></stop> </lineargradient> <lineargradient id="pc-yellow" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(43,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(23,90%,55%)"></stop> </lineargradient> <lineargradient id="pc-blue" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(223,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(203,90%,55%)"></stop> </lineargradient> <lineargradient id="pc-purple" x1="1" y1="0.5" x2="0" y2="0.5"> <stop offset="0%" stop-color="hsl(283,90%,55%)"></stop> <stop offset="100%" stop-color="hsl(263,90%,55%)"></stop> </lineargradient> </defs> <!-- Days of Month --> <g data-units="d"> <circle class="progress-clock__ring" cx="128" cy="128" r="74" fill="none" opacity="0.1" stroke="url(#pc-red)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="mo" cx="128" cy="128" r="74" fill="none" stroke="url(#pc-red)" stroke-width="12" stroke-dasharray="465 465" stroke-dashoffset="364.5843981481482" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> <!-- Hours of Day --> <g data-units="h"> <circle class="progress-clock__ring" cx="128" cy="128" r="90" fill="none" opacity="0.1" stroke="url(#pc-yellow)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="d" cx="128" cy="128" r="90" fill="none" stroke="url(#pc-yellow)" stroke-width="12" stroke-dasharray="565.5 565.5" stroke-dashoffset="294.95013888888883" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> <!-- Minutes of Hour --> <g data-units="m"> <circle class="progress-clock__ring" cx="128" cy="128" r="106" fill="none" opacity="0.1" stroke="url(#pc-blue)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="h" cx="128" cy="128" r="106" fill="none" stroke="url(#pc-blue)" stroke-width="12" stroke-dasharray="666 666" stroke-dashoffset="344.84" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> <!-- Seconds of Minute --> <g data-units="s"> <circle class="progress-clock__ring" cx="128" cy="128" r="122" fill="none" opacity="0.1" stroke="url(#pc-purple)" stroke-width="12"></circle> <circle class="progress-clock__ring-fill" data-ring="m" cx="128" cy="128" r="122" fill="none" stroke="url(#pc-purple)" stroke-width="12" stroke-dasharray="766.5 766.5" stroke-dashoffset="51.09999999999999" stroke-linecap="round" transform="rotate(-90,128,128)"></circle> </g> </svg> </div> <script type="text/javascript"> 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 "星期一"; case 2: return "星期二"; case 3: return "星期三"; case 4: return "星期四"; case 5: return "星期五"; case 6: return "星期六"; default: return "星期日"; } } getMonthInfo(mo, yr) { switch (mo) { case 1: return { name: "02月", days: yr % 4 === 0 ? 29 : 28 }; case 2: return { name: "03月", days: 31 }; case 3: return { name: "04月", days: 30 }; case 4: return { name: "05月", days: 31 }; case 5: return { name: "06月", days: 30 }; case 6: return { name: "07月", days: 31 }; case 7: return { name: "08月", days: 31 }; case 8: return { name: "09月", days: 30 }; case 9: return { name: "10月", days: 31 }; case 10: return { name: "11月", days: 30 }; case 11: return { name: "12月", days: 31 }; default: return { name: "01月", 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: "y", value: year }, { label: "w", value: dayOfWeekName }, { label: "mo", value: monthInfo.name, progress: mo_progress }, { label: "d", value: day < 10 ? "0" + day : day, progress: d_progress }, { label: "h", value: hr > 12 ? ((hr - 12) < 10 ? "0" + (hr - 12) : (hr - 12)) : (hr < 10 ? "0" + hr : 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); } } </script> </body></html>
暂无评论内容