ویژگی تصویر

افکت موج دار متن با CSS

  /  CSS   /  افکت موج دار متن با CSS
بنر تبلیغاتی الف

افکت موج دار متن با CSS یکی از جلوه‌های بصری پرکاربرد برای جلب‌توجه کاربر و ایجاد احساس پویا روی وب‌سایت‌ها است. این افکت می‌تواند به‌صورت ساده و سبک یا پیچیده و تعاملی اجرا شود؛ از متن‌هایی که به‌طور کامل موج می‌زنند تا حروفی که به صورت ترتیبی بالا و پایین می‌روند. در ادامه روش‌های مختلف، نمونه‌های کد عملی، نکات بهینه‌سازی و دسترس‌پذیری را بررسی می‌کنیم.

روش‌های رایج برای ایجاد موج متن

  • انیمیشن حروف با استفاده از span و keyframes (CSS خالص)
  • استفاده از SVG و مسیرهای موجی (textPath و animate)
  • تکنیک background-clip: text برای ایجاد گرادینت متحرک و توهم موج
  • استفاده از ماسک‌ها (mask) و filter برای جلوه‌های پیچیده‌تر

مثال 1 — موج ساده با span و keyframes

/* HTML */<h1 class="wave"><span style="--i: 0;">و</span><span style="--i: 1;">ا</span><span style="--i: 2;">ف</span><span style="--i: 3;">ک</span><span style="--i: 4;">ت</span></h1>
/* CSS */ .wave { display:inline-block; font-size:48px; white-space:nowrap; } .wave span { display:inline-block; transform-origin:50% 50%; animation: wave 1.2s ease-in-out infinite; animation-delay: calc(var(--i) * 0.08s); } @keyframes wave { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }

این کد هر حرف را در یک عنصر span قرار می‌دهد و با استفاده از animation-delay باعث می‌شود حروف به ترتیب موج بسازند. مقدار --i برای هر حرف تنظیم می‌شود تا تاخیر افزایشی ایجاد شود.

توضیح و بهبود

این روش خیلی ساده و قابل فهم است اما نوشتن دستی span برای متن‌های طولانی دشوار است. برای خودکارسازی می‌توانید با جاوااسکریپت DOM یا پیش‌پردازنده‌ای مثل PHP یا قالب‌های سمت سرور حروف را جدا کنید. همچنین برای کاهش CPU بهتر است از transform استفاده کنید نه تغییرات layout.

مثال 2 — موج متن با CSS متغیرها و nth-child کمتر

/* HTML */<h1 class="wave2">موجی سازی متن با CSS</h1>
/* CSS */ .wave2 { font-size:48px; display:inline-block; } .wave2::after { content: attr(data-text); display:inline-block; } .wave2 span { display:inline-block; animation: w 1.1s linear infinite; } .wave2 span { animation-delay: calc(var(--n) * 0.06s); } @keyframes w { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-10px); } }

در این نسخه فرض بر این است که متن به span‌های حروف با متغیری مثل --n تقسیم شده است. این روش با استفاده از یک چرخه‌ی CSS و متغیرها خواناتر و قابل تنظیم‌تر می‌شود؛ اما تولید spanها معمولاً با اسکریپت سمت کاربر یا سرور انجام می‌پذیرد.

مثال 3 — موج با SVG و textPath (قابل دستکاری و دقیق)

<svg width="600" height="120" viewBox="0 0 600 120">
  <defs>
    <path id="wavePath" d="M0 60 Q 75 20 150 60 T 450 60 T 600 60" />
  </defs>
  <text font-size="36" fill="#222">
    <textPath href="#wavePath" startOffset="0">متن موجی در طول مسیر</textPath>
  </text>
</svg>

این روش از یک مسیر (path) موجی استفاده می‌کند و متن مطابق آن مسیر قرار می‌گیرد. با تغییر مسیر می‌توانید شکل دقیق موج را کنترل کنید. SVG برای انیمیشن‌های پیچیده‌تر و واکنش‌پذیری عالی است و قابلیت آنتی‌آلیاسینگ بهتری دارد.

انیمیشن مسیر

<animate xlink:href="#wavePath" attributeName="d" dur="3s" repeatCount="indefinite"
  values="M0 60 Q75 20 150 60 T450 60 T600 60;
          M0 60 Q75 100 150 60 T450 60 T600 60;
          M0 60 Q75 20 150 60 T450 60 T600 60" />

با افزودن تگ animate روی path می‌توان موج را پویا کرد؛ اما توجه کنید که پشتیبانی مرورگرها و پیچیدگی عملکرد باید در نظر گرفته شود.

تکنیک background-clip برای توهم موج

.clip {
  font-size:64px;
  background: linear-gradient(90deg,#ff7a7a,#7afcff,#7affb2);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  background-size: 200% 100%;
  animation: slide 4s linear infinite;
}
@keyframes slide { 0%{ background-position:0 0 } 100%{ background-position:-100% 0 } }

روش background-clip: text گرادینت متحرک روی متن ایجاد می‌کند و با ترکیب ماسک یا SVG می‌توان حس موج را تقویت نمود. این روش بار پردازشی کمتری نسبت به انیمیشن هر حرف دارد اما واقعی‌تر از حرکت حروف نیست.

نکات دسترس‌پذیری و سازگاری

  • حواس‌پرتی: انیمیشن‌های شدید می‌توانند برای برخی کاربران مزاحمت ایجاد کنند. از @media (prefers-reduced-motion: reduce) استفاده کنید تا انیمیشن کاهش یابد یا حذف شود.
  • خوانایی: مطمئن شوید کنتراست متن حفظ می‌شود؛ انیمیشن نباید خواندن را دشوار کند.
  • پشتیبانی مرورگر: SVG و CSS مدرن اغلب پشتیبانی می‌شوند اما ویژگی‌هایی مثل background-clip:text در همه موتورهای قدیمی کار نمی‌کند—برای آن fallback در نظر بگیرید.

جدول مقایسه روش‌ها

روشمزایامعایب
span + keyframesکنترل دقیق روی هر حرف، سادهنیاز به تولید span، ممکن است سنگین شود
SVG textPathدقت بالا، ظاهر صاف، مسیرهای پیچیدهیادگیری SVG لازم است، پیچیدگی بیشتر
background-clipسبک، آسان برای گرادینت‌های متحرکتوهم موج نه واقعی، پشتیبانی ناقص در برخی مرورگرها

بهینه‌سازی و نکات فنی

  • از transform و opacity برای انیمیشن استفاده کنید تا از repaint/layout جلوگیری شود.
  • حدود فریم و مدت زمان را معقول انتخاب کنید (مثلاً 0.8s تا 2s) تا مصرف CPU کم باشد.
  • برای متن‌های طولانی از تکنیک‌های مبتنی بر SVG یا background استفاده کنید تا نیازی به spanهای متعدد نباشد.
  • برای انیمیشن‌های سنگین، می‌توانید با requestAnimationFrame یا WebGL جایگزین‌های بهینه‌تر بسازید اما پیچیدگی افزایش می‌یابد.

نمونه کد برای کاهش حرکت (prefers-reduced-motion)

@media (prefers-reduced-motion: reduce) {
  .wave span { animation: none !important; transform: none !important; }
}

این قطعه تضمین می‌کند که کاربرانی که حرکت را کاهش داده‌اند، انیمیشن را نمی‌بینند و متن ثابت است؛ یک اصل مهم دسترس‌پذیری.

نتیجه‌گیری و پیشنهادات عملی

افکت موج دار متن با CSS می‌تواند تجربه بصری جذابی ایجاد کند اما باید با دقت و توجه به عملکرد و دسترس‌پذیری پیاده‌سازی شود. برای پروژه‌های ساده از روش span + keyframes استفاده کنید؛ برای کنترل دقیق‌تر و گرافیک حرفه‌ای از SVG بهره ببرید؛ و برای متن‌های طولانی یا وقتی که بار پردازشی باید کم باشد، ترکیب background-clip و ماسک انتخاب بهتری است.

در نهایت، همیشه تست در مرورگرها و دستگاه‌های مختلف، و رعایت prefers-reduced-motion و کنتراست، تضمین می‌کند تجربه‌ای هم جذاب و هم قابل دسترس ارائه دهید.

آیا این مطلب برای شما مفید بود ؟

خیر
بله
موضوعات شما در انجمن: