ویژگی تصویر

افکت پالس نور در متن با CSS

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

افکت پالس نور یا نور ضربانی (light pulse) یکی از جلوه‌های زیبا و پرکاربرد برای برجسته کردن متن در وب‌سایت است. این افکت می‌تواند توجه کاربر را به عنوان‌های صفحه، دکمه‌ها یا CTAها جلب کند. در این مقاله روش‌های مختلف پیاده‌سازی، نکات عملکردی، دسترس‌پذیری و نمونه‌های عملی را با کدهای واقعی بررسی می‌کنیم.

چرا افکت پالس نور مفید است؟

  • جلب توجه بصری بدون استفاده از تصاویر یا ویدیو.
  • قابلیت تنظیم دقیق رنگ، شدت و سرعت.
  • قابلیت ترکیب با سایر افکت‌ها مانند شیمِر (shimmer) یا سایه متن (text-shadow).

روش‌های رایج پیاده‌سازی

معمول‌ترین روش‌ها شامل استفاده از:

  • text-shadow و keyframes برای ایجاد نور ضربانی.
  • pseudo-element با gradient و blend-mode برای شیمِر و نور متحرک.
  • SVG filters برای کنترل دقیق‌تر و افت کیفیت کمتر در بعضی موارد.

نمونه ساده با text-shadow

/* Basic pulsing glow using text-shadow */.pulse-text {
  font-size: 48px;
  color: #fff;
  text-shadow: 0 0 6px rgba(255,255,255,0.6);
  animation: pulse 1.8s ease-in-out infinite;
}

@keyframes pulse {
  0% {
    text-shadow: 0 0 6px rgba(255,255,255,0.2);
    transform: translateZ(0);
  }
  50% {
    text-shadow: 0 0 20px rgba(255,255,255,0.9);
  }
  100% {
    text-shadow: 0 0 6px rgba(255,255,255,0.2);
  }
}

این کد یک افکت پالس ساده با text-shadow ایجاد می‌کند. animation با keyframes اندازه و شدت سایه متن را تغییر می‌دهد. transform: translateZ(0) به مرورگر کمک می‌کند تا از شتاب‌دهی سخت‌افزاری استفاده کند و روانی انیمیشن را افزایش دهد.

نسخه بهینه‌تر: استفاده از pseudo-element و background-clip

/* Optimized shimmer/pulse using pseudo-element and background */.pulse-shimmer {
  position: relative;
  display: inline-block;
  font-size: 48px;
  color: #fff;
  background: linear-gradient(90deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.25) 50%, rgba(255,255,255,0.06) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.pulse-shimmer::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,0.9), rgba(255,255,255,0) 40%);
  mix-blend-mode: screen;
  opacity: 0;
  transform: scale(0.9);
  animation: shimmerPulse 1.6s ease-in-out infinite;
  pointer-events: none;
}

@keyframes shimmerPulse {
  0% { opacity: 0; transform: scale(0.9); }
  50% { opacity: 1; transform: scale(1.05); }
  100% { opacity: 0; transform: scale(0.9); }
}

در این نسخه از pseudo-element (::before) و background-clip استفاده شده تا متن با گرادیان پوشانده شود و نور ضربانی به شکل radial در بالای متن قرار گیرد. mix-blend-mode باعث ترکیب مناسب نور با متن می‌شود و pointer-events: none از تداخل با تعامل جلوگیری می‌کند. این روش معمولاً از نظر عملکرد بهتر از تغییر مداوم text-shadow در متن‌های طولانی است.

دسترسی و کاربر پسند بودن (Accessibility)

حرکت زیاد یا نور چشمک‌زن ممکن است برای برخی کاربران مشکل‌ساز باشد. حتماً موارد زیر را رعایت کنید:

  • استفاده از @media (prefers-reduced-motion: reduce) برای غیرفعال کردن یا کاهش انیمیشن.
  • حفظ کنتراست کافی متن در حالت استاتیک.
  • اجتناب از انیمیشن‌های سریع یا مکرر برای عناصر مهم که کاربران باید سریع به آن‌ها واکنش نشان دهند.

نمونه با prefers-reduced-motion

@media (prefers-reduced-motion: reduce) {
  .pulse-text, .pulse-shimmer {
    animation: none;
    text-shadow: none;
    background: none;
    color: #fff; /* ensure legibility */  }
}

این قطعه کد برای کاربرانی که در تنظیمات سیستمی خود درخواست کاهش حرکت کرده‌اند، انیمیشن‌ها را غیرفعال می‌کند و به حالت ایستا برمی‌گردد.

مقایسه روش‌ها — مزایا و معایب

روشمزایامعایب
text-shadow + keyframesساده، پشتیبانی وسیعبار پردازشی روی متن زیاد در موارد متعدد
pseudo-element + gradientعملکرد بهتر، کنترل بصری بیشترنیاز به background-clip برای برش متن، مشکلات در بعضی مرورگرها
SVG filterکنترل دقیق و افکت‌های پیچیدهپیچیدگی بیشتر، کدنویسی طولانی‌تر

نکات عملکردی و بهترین شیوه‌ها

  • برای متن‌های طولانی از روش pseudo-element استفاده کنید تا از repaintهای مکرر جلوگیری شود.
  • از transform و opacity استفاده کنید، نه ویژگی‌هایی که باعث layout یا paint کامل می‌شوند.
  • انیمیشن را به عناصر منتخب (مثلاً عنوان اصلی یا دکمه CTA) محدود کنید، نه کل صفحه.
  • برای موبایل، شدت و سرعت را کاهش دهید تا عمر باتری و عملکرد دستگاه حفظ شود.

کاربردهای واقعی و مثال‌های استفاده

  • عنوان صفحات تبلیغاتی و لندینگ پیج‌ها برای جلب توجه اولیه.
  • دکمه‌های CTA در فروشگاه‌های آنلاین برای هدایت کاربر به خرید.
  • هدر بازی‌ها یا وب‌آپ‌های تعاملی برای ایجاد حس پویایی.
  • اطلاعیه‌های مهم یا پیام‌های هشدار با حساسیت بالا.

نتیجه‌گیری و توصیه‌های نهایی

افکت پالس نور در متن با CSS می‌تواند جلوهٔ بصری جذابی ایجاد کند اما باید با دقت اجرا شود. انتخاب روش مناسب بستگی به نیاز پروژه، گسترهٔ پشتیبانی مرورگر و الزامات دسترس‌پذیری دارد. همیشه تست روی دستگاه‌های مختلف و رعایت prefers-reduced-motion را در نظر داشته باشید.

در صورت نیاز می‌توانیم برای پروژهٔ شما نمونهٔ سفارشی بسازیم یا نسخهٔ SVG/Canvas برای افکت‌های پیچیده‌تر ارائه دهیم.

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

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