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&amp;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