ویژگی تصویر

طراحی تقویم زیبا با CSS — راهنمای جامع

  /  CSS   /  طراحی تقویم زیبا با CSS
بنر تبلیغاتی الف

تقویم جزء اجزای پرکاربرد در وب‌سایت‌ها و اپلیکیشن‌ها است. با ترکیب HTML معنایی، CSS مدرن و کمی جاوااسکریپت می‌توان تقویمی ایجاد کرد که هم زیبا باشد و هم دسترس‌پذیر و قابل سفارشی‌سازی. در این مقاله به روش‌های طراحی، الگوهای متداول، نمونه‌های عملی و نکات بهینه‌سازی می‌پردازیم.

چرا طراحی تقویم با CSS مهم است؟

  • ظاهر و تجربه کاربری: تقویم خوب کمک می‌کند کاربران سریع‌تر تاریخ‌ها و رویدادها را ببینند.
  • عملکرد و دسترس‌پذیری: استفاده از HTML معنایی و استایل مناسب باعث می‌شود تقویم برای کاربرانی که از صفحه‌خوان استفاده می‌کنند قابل فهم باشد.
  • قابلیت سفارشی‌سازی: CSS متغیرها و مدهای تم (روشن/تاریک) امکان تغییر سریع ظاهر را می‌دهند.

المان‌های پایه برای یک تقویم HTML/CSS

معمولاً یک تقویم شامل هدر ماه، ردیف روزهای هفته و سلول‌های روز است. می‌توان از CSS Grid یا flexbox برای چیدمان استفاده کرد. در ادامه یک نمونه ساده با Grid و JavaScript برای تولید روزها می‌آوریم.

/* styles.css */:root{
  --bg: #f8fafc;
  --card: #ffffff;
  --accent: #2563eb;
  --muted: #6b7280;
  --today-bg: #e0f2fe;
  --radius: 12px;
}

.calendar {
  width: 320px;
  background: var(--card);
  border-radius: var(--radius);
  box-shadow: 0 6px 18px rgba(2,6,23,0.08);
  padding: 16px;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
}

.calendar-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.month {
  font-weight: 600;
  color: #0f172a;
}

.grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}

.cell {
  padding: 10px;
  text-align: center;
  border-radius: 8px;
  color: var(--muted);
  background: transparent;
  transition: background 200ms, transform 120ms;
}

.cell:hover {
  background: rgba(37,99,235,0.08);
  transform: translateY(-3px);
}

.cell.today {
  background: var(--today-bg);
  color: var(--accent);
  font-weight: 700;
}

کد بالا استایل پایه تقویم را تعریف می‌کند: متغیرهای رنگی، کارت تقویم، هدر، شبکه ۷ ستونه و کلاس‌های سلول. کلاس .today روز جاری را برجسته می‌کند.

نمونه HTML و اسکریپت تولید روزها

<div class="calendar">
  <div class="calendar-header">
    <button id="prev"></button>
    <div class="month" id="monthLabel"></div>
    <button id="next"></button>
  </div>
  <div class="grid" id="calendarGrid"></div>
</div>

<script>
const grid = document.getElementById('calendarGrid');
const monthLabel = document.getElementById('monthLabel');

let current = new Date();

function render(date){
  grid.innerHTML = '';
  const year = date.getFullYear();
  const month = date.getMonth();
  monthLabel.textContent = date.toLocaleString('default',{month:'long', year:'numeric'});

  const firstDay = new Date(year, month, 1).getDay();
  const daysInMonth = new Date(year, month + 1, 0).getDate();

  // weekdays header
  const weekdays = ['Sun','Mon','Tue','Wed','Thu','Fri','Sat'];
  weekdays.forEach(w => {
    const el = document.createElement('div');
    el.className = 'cell';
    el.style.fontWeight = '600';
    el.textContent = w;
    grid.appendChild(el);
  });

  // empty cells
  for(let i=0;i<firstDay;i++){
    const el = document.createElement('div');
    el.className = 'cell';
    grid.appendChild(el);
  }

  for(let d=1; d<=daysInMonth; d++){
    const el = document.createElement('div');
    el.className = 'cell';
    el.textContent = d;
    const today = new Date();
    if(d === today.getDate() && month === today.getMonth() && year === today.getFullYear()){
      el.classList.add('today');
    }
    grid.appendChild(el);
  }
}

document.getElementById('prev').addEventListener('click', () => {
  current.setMonth(current.getMonth() - 1);
  render(current);
});
document.getElementById('next').addEventListener('click', () => {
  current.setMonth(current.getMonth() + 1);
  render(current);
});

render(current);
</script>

این اسکریپت HTML تقویم را با روزهای هفته و روزهای ماه پر می‌کند، دکمه‌های قبلی و بعدی را مدیریت می‌کند و روز جاری را با کلاس today مشخص می‌کند. توجه کنید که برای استفاده در پروژه، اسکریپت را بیرون فایل HTML یا در انتهای بدنه قرار دهید تا المان‌ها قابل دسترسی باشند.

افزودن رویدادها و نشانه‌گذاری بصری

برای نمایش رویدادها می‌توان از نقاط رنگی، لیست رویداد در کنار تقویم یا پنل شناور استفاده کرد. نمونه CSS برای نقطه رویداد:

.event-dot{
  width: 7px;
  height: 7px;
  border-radius: 50%;
  display: inline-block;
  margin-left: 6px;
  vertical-align: middle;
}

این کلاس را می‌توان به داخل هر سلول اضافه کرد و با رنگ‌های مختلف نوع رویداد را نشان داد. همچنین بهتر است اطلاعات رویدادها در DOM نیز موجود باشد تا صفحه‌خوان‌ها بتوانند آن‌ها را بخوانند (مثلاً با aria-label).

دسترسی (Accessibility) و سئو

  • برای دسترس‌پذیری، از HTML معنایی استفاده کنید: اگر تقویم تعاملی است از نقش‌ها (role=”grid”) و aria-selected برای سلول‌های انتخاب‌شده بهره ببرید.
  • از تگ‌های متنی برای نام ماه و روزها استفاده کنید تا موتورهای جستجو و خوانندگان صفحه‌نمایش متن را بخوانند.
  • سرعت بارگذاری: CSS را مینیمال نگه دارید و از تصاویر سنگین پرهیز کنید.

واکنش‌گرایی و تمپلیت‌های مختلف

در موبایل می‌توانید تقویم را به نمایش لیستی تبدیل کنید یا اندازه سلول‌ها را تغییر دهید. استفاده از grid-template-columns: repeat(7, minmax(0,1fr)) و مدیا کوئری‌ها به تغییر چیدمان کمک می‌کند. نمونه تغییر برای موبایل:

@media (max-width: 420px){
  .calendar { width: 100%; padding: 12px; }
  .grid { gap: 4px; }
  .cell { padding: 8px; font-size: 14px; }
}

این مدیا کوئری ابعاد، فواصل و اندازه متن را برای صفحات کوچک‌تر بهینه می‌کند.

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

  • استفاده از CSS متغیرها برای ساخت تم‌های سریع و سوییچ بین حالت روشن/تاریک.
  • تعریف transition ملایم برای hover و تغییر ماه تا تجربه روان‌تری داشته باشید.
  • اگر تقویم پیچیده است (فیلتر رویداد، کشیدن و رها کردن)، بهتر است منطق مربوطه در وب‌ورکر یا بهینه‌سازی شده نوشته شود تا UI قفل نشود.
  • برای تقویم‌های بین‌المللی تاریخ‌ها و شروع هفته را براساس locale و ترجیحات کاربر تنظیم کنید.

نمونه جدول کوتاه برای متغیرهای رنگی

متغیرکاربردمثال
–accentرنگ اصلی هاشور و برجسته‌سازی#2563eb
–today-bgپس‌زمینه روز جاری#e0f2fe
–cardپس‌زمینه کارت تقویم#ffffff

خلاصه و پیشنهادات اجرایی

  • برای شروع از CSS Grid استفاده کنید؛ ساده، قابل فهم و انعطاف‌پذیر است.
  • روزهای هفته و هدر ماه باید قابل خواندن و معنایی باشند تا SEO و دسترس‌پذیری حفظ شود.
  • رویدادها را در DOM نگه دارید و فقط با CSS نشان بدهید تا اطلاعات برای موتورهای جستجو و صفحه‌خوان‌ها نیز قابل دسترسی باشد.
  • پروفایلینگ کنید: اگر تقویم با هزاران رویداد کار می‌کند، از lazy rendering یا pagination استفاده کنید.

با رعایت این اصول می‌توانید تقویمی زیبا، سریع و قابل‌دسترسی طراحی کنید که روی انواع دستگاه‌ها به‌خوبی کار کند. کدهای نمونه بالا به‌عنوان نقطه شروع مناسب هستند و می‌توان بر اساس نیازهای پروژه آن‌ها را توسعه داد.

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

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