AziziStudio Logo AziziStudio
تماس

Container Queries و انتخاب‌گر :has()

Container Queries و انتخاب‌گر :has() دو قابلیت جدید در CSS هستند که طراحی واکنش‌پذیر را هوشمندتر و سبک‌تر می‌کنند. با استفاده از آن‌ها می‌توان بدون جاوااسکریپت، رفتار کامپوننت‌ها را بر اساس اندازه ظرف یا وجود عناصر خاص کنترل کرد.

Container Queries چیست؟

به‌جای اینکه استایل‌ها را بر اساس اندازه کل صفحه (viewport) تنظیم کنیم، می‌توانیم آن‌ها را بر اساس اندازه ظرف (container) تنظیم کنیم. این یعنی هر کامپوننت می‌تواند در جای مختلف رفتار متفاوتی داشته باشد.


.card-grid {
  container-type: inline-size;
  container-name: cards;
}

@container cards (min-width: 600px) {
  .card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
    

:has() چیست؟

انتخاب‌گر :has() به CSS امکان شرط‌گذاری می‌دهد. مثلاً می‌توان گفت اگر یک کارت تصویر دارد، padding آن متفاوت باشد. یا اگر فرم ورودی خالی است، دکمه غیرفعال شود.


.card:has(img) {
  padding: 12px;
  display: grid;
  grid-template-columns: 120px 1fr;
}

.form:has(input[value=""]) .submit {
  opacity: 0.6;
  pointer-events: none;
}
    

نتیجه؟ طراحی واکنش‌پذیر دقیق‌تر، کد کمتر، و تجربه کاربری بهتر بدون نیاز به جاوااسکریپت. این دو قابلیت برای ساخت کامپوننت‌های مدرن و مستقل بسیار کاربردی هستند.