נלמד איך ליצור את אפקט הטקסט המנופח עם שינוי הדרגתי באמצעות מאפיינים מותאמים אישית ברמת ההיקף ו-background-clip.
עוברים אל CodePen ויוצרים עט חדש.
יוצרים את הרכיבים של ה-Markup לטקסט. נשתמש בכותרת עם המילה 'מהיר':
<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);
}
יוצרים שני מאפיינים מותאמים אישית לצבעים שבהם נשתמש. מחילים 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 (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
.
הנה הסרטון הקצר עם הטיפים האלה! ⚡️
רוצים לקבל את זה בפורמט של ציוץ? 🐦
המשך יום מצוין! ʕ •ᴥ•ʔ
תמונה ראשית (Hero) של ולדיסלב קלפין בסרטון Un פעילות