มาสร้างเอฟเฟกต์ข้อความไล่ระดับสีแบบเคลื่อนไหวด้วยพร็อพเพอร์ตี้ที่กำหนดเองระดับขอบเขตและ 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