เคล็ดลับ CSS อย่างรวดเร็ว ข้อความไล่ระดับสีแบบเคลื่อนไหว

มาสร้างเอฟเฟกต์ข้อความไล่ระดับสีแบบเคลื่อนไหวด้วยพร็อพเพอร์ตี้ที่กำหนดเองระดับขอบเขตและ background-clip

ไปที่ CodePen แล้วสร้าง Pen ใหม่

สร้างมาร์กอัปสำหรับข้อความ มาลองใช้ส่วนหัวที่มีคำว่า "รวดเร็ว" กัน

<h1 class="boujee-text">Hello!</h1>

จากนั้นมาทำให้ body ของเรามี background-color สีเข้มขึ้นกัน

body {
  display: grid;
  place-items: center;
  min-height: 100vh;
  background: hsl(0 0% 20%);
}

เพิ่ม font-size ในข้อความ ใช้ clamp เพื่อทำให้เป็นแบบที่ปรับเปลี่ยนตามอุปกรณ์

.boujee-text {
  font-size: clamp(3rem, 25vmin, 8rem);
}

สร้างพร็อพเพอร์ตี้ที่กำหนดเอง 2 รายการสำหรับสีที่เราจะใช้ ใช้ linear-gradient กับ background โดยใช้สีเหล่านั้นและหมุน 90 องศา

.boujee-text {
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / 100% 100%;
}

สร้างพร็อพเพอร์ตี้ที่กำหนดเองซึ่งคุณใช้สำหรับขนาดพื้นหลังแนวนอนได้ ใช้สำหรับ background-size-x

.boujee-text {
  --bg-size: 400%;
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / var(--bg-size) 100%;
}

หากต้องการตัดพื้นหลังให้อยู่ภายในข้อความ ให้ตั้งค่า color เป็น transparent และตั้งค่า background-clip: text ดังนี้

.boujee-text {
  --bg-size: 400%;
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / var(--bg-size) 100%;
  color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
}

ที่จุดนี้ คุณอาจปล่อยทิ้งไว้ตรงนั้นแล้วทดสอบด้วย background-position และการไล่ระดับสีที่ใช้ใน background-image หรือคุณอาจสร้างภาพเคลื่อนไหวด้วยการไล่ระดับสีทั่วทั้งข้อความ ก่อนอื่น ให้กำหนดคีย์เฟรมสำหรับภาพเคลื่อนไหว ซึ่งจะใช้พร็อพเพอร์ตี้ที่กำหนดเอง --bg-size ที่คุณกำหนดไว้ก่อนหน้านี้ ตัวอย่างที่ดีของพร็อพเพอร์ตี้ที่กำหนดเองระดับขอบเขตซึ่งช่วยให้การบำรุงรักษาง่ายขึ้น

@keyframes move-bg {
  to {
    background-position: var(--bg-size) 0;
  }
}

จากนั้นใช้ภาพเคลื่อนไหวโดยใช้ animation

.boujee-text {
  --bg-size: 400%;
  --color-one: hsl(15 90% 55%);
  --color-two: hsl(40 95% 55%);
  font-size: clamp(3rem, 25vmin, 8rem);
  background: linear-gradient(
                90deg,
                var(--color-one),
                var(--color-two),
                var(--color-one)
              ) 0 0 / var(--bg-size) 100%;
  color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
  animation: move-bg 8s infinite linear;
}

หากต้องการดำเนินการต่อ คุณสามารถรวมโค้ดภาพเคลื่อนไหวไว้ใน Media Query เพื่อเคารพค่ากําหนดของผู้ใช้เกี่ยวกับการเคลื่อนไหว ดังนี้

@media (prefers-reduced-motion: no-preference) {
  .boujee-text {
    animation: move-bg 8s linear infinite;
  }
  @keyframes move-bg {
    to {
      background-position: var(--bg-size) 0;
    }
  }
}

เสร็จแล้ว 🎉 คุณสร้างข้อความไล่ระดับสีแบบเคลื่อนไหวด้วย CSS โดยใช้พร็อพเพอร์ตี้ที่กำหนดเองระดับขอบเขตและ background-clip แล้ว

ลองดูเคล็ดลับนี้ในรูปแบบวิดีโอที่รวดเร็ว ⚡️

หากต้องการดูข้อมูลนี้ในรูปแบบทวีต 🐦

Stay Awesome! ʕ •ᴥ•ʔ

รูปภาพหลักโดย Vladislav Klapin ใน Unsplash