css+js实现幽灵火车发车到站时刻表代码
代码语言:html
所属分类:表格
代码描述:css+js实现幽灵火车发车到站时刻表代码
代码标签: css js 幽灵 火车 发车 到站 时刻表 代码
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en" > <head> <meta charset="UTF-8"> <link rel='stylesheet' href='https://fonts.googleapis.com/css2?family=Rubik:wght@400;500;700&display=swap'> <style> :root { --title: "Ghost Train Schedule"; --author: "Matt Cannon"; --contact: "mc@mattcannon.design"; --description: "A hauntingly animated split-flap board that displays arrivals and departures from the underworld's most trusted railway, Damnedtrak®."; --keywords: "ghost train, split-flap, schedule board, arrivals departures, halloween, animation, css grid, javascript animation, spooky ui, codepenchallenge, cpc-halloween-time, ui design, front-end, rubik font, motion design"; --last-modified: "2025-10-06"; --content-language: "en"; --generator: "HTML5, CSS3, JavaScript"; --bg: #0b0e13; --ink: #e8f0ff; --muted: #8d98ad; --ontime: #8cffd5; --arrived: #00c673; --warn: #ffcc33; --bad: #ff4b61; --weird: #66e7ff; --gap: 17px; --cell-h: 25px; } * { box-sizing: border-box; } body { margin: 0; font-family: "Rubik", sans-serif; background: radial-gradient(1200px 600px at 70% -10%, #1b2230 0%, var(--bg) 60%) no-repeat; color: var(--ink); } .station-bg { display: flex; justify-content: center; align-items: flex-start; padding: 20px; min-height: 100dvh; max-height: 90vh; overflow: hidden; padding-top: 85px; } .bezel { width: 92%; max-width: 880px; border-radius: 20px; background: linear-gradient(#0d1116, #0b0e13); box-shadow: 0 25px 70px #000a, inset 0 1px 0 #ffffff12; padding: 18px 20px 24px; display: flex; flex-direction: column; } .bezel__plate { position: relative; height: 50px; display: flex; align-items: center; justify-content: flex-start; background: #0d1116; border: 1px solid #1b2433; border-radius: 12px; margin-bottom: 12px; padding: 0 16px; } .logo-img { width: 300px; height: 40px; object-fit: cover; border-radius: 6px; opacity: 0.95; margin: 0; } .mast { position: absolute; right: 7px; top: 50%; transform: translateY(-50%); margin: 0; } .mode select { background: #0c1015; color: var(--ink); border: 1px solid #f15f0a; border-radius: 8px; padding: 6px 44px 6px 14px; font-family: "Rubik", sans-serif; font-size: 15px; cursor: pointer; appearance: none; background-image: url("data:image/svg+xml;utf8,<svg fill='%23b4b6bb' xmlns='http://www.w3.org/2000/svg' width='24' height='24'><path d='M6 9l6 6 6-6z'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; background-size: 20px; } .marquee { position: relative; overflow: hidden; border-top: 1px solid #1c2432; border-bottom: 1px solid #1c2432; margin: 10px 0 14px; height: 28px; } .marquee__track { position: absolute; inset: 0; display: inline-block; white-space: nowrap; will-change: transform; animation: scroll 50s linear infinite; } .marquee__track span { display: inline-block; font-size: 14px; color: #b4b6bb; font-weight: 500; letter-spacing: 0.03em; padding-right: 60px; } @keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } } .board { background: linear-gradient(#0e141b, #0b0f14); border: 1px solid #1b2633; border-radius: 12px; display: grid; grid-template-columns: repeat(5, minmax(110px, 1fr)); gap: var(--gap); padding: 14px; box-shadow: inset 0 1px 2px #ffffff10; } .board__head { text-transform: uppercase; color: var(--muted); font-size: 12px; letter-spacing: 0.15em; padding-bottom: 4px; font-weight: 500; text-align: center; } .cell { position: relative; height: var(--cell-h); perspective: 800px; } .slot { position: relative; width: 100%; height: 100%; border-radius: 8px; background: #0c1117; overflow: hidden; text-align: center; box-shadow: inset 0 -1px 6px #000a; } .slot::before { content: ""; position: absolute; left: 0; right: 0; top: 50%; height: 1px; background: linear-gradient(90deg, transparent, #000 20%, #000 80%, transparent); opacity: 0.6; transform: translateY(-0.5px); } .slot .half { position: absolute; left: 0; right: 0; height: 50%; overflow: hidden; } .slot .half .txt { display: block; height: var(--cell-h); line-height: var(--cell-h); font-size: 15px; font-weight: 400; white-space: nowrap; } .top { top: 0; background: #0f141b; } .bottom { bottom: 0; background: #0c1117; } .bottom .txt { transform: translateY(calc(var(--cell-h) * -0.5)); } .top-flip { top: 0; background: #0f141b; transform-origin: bottom; animation: flipTop 0.42s ease-in forwards; z-index: 2; } .bottom-flip { bottom: 0; background: #0c1117; transform-origin: top; animation: flipBottom 0.42s ease-out 0.42s forwards; z-index: 1; } .bottom-flip .txt { transform: translateY(calc(var(--cell-h) * -0.5)); } @keyframes flipTop { to { transform: rotateX(-90deg); } } @keyframes flipBottom { from { transform: rotateX(90deg); } to { transform: rotateX(0); } } .cell[data-col="Time"] .txt, .cell[data-col="Status"] .txt { font-weight: 700; } .cell[data-col="Status"][data-status="On time"] .slot { color: var(--ontime); } .cell[data-col="Status"][data-status="Arrived"] .slot { color: var(--arrived); } .cell[data-col="Status"][data-status="Boarding"] .slot { color: var(--warn); } .cell[data-col="Status"][data-status="Delayed"] .slot { color: var(--bad); } .cell[data-col="Status"][data-status="Manifesting"] .slot { color: var(--weird); } </style> </head> <body translate="no"> <div class="station-bg"> <div class="bezel"> <div class="bezel__plate"> <img src=".........完整代码请登录后点击上方下载按钮下载查看
网友评论0