در حال بارگذاری...

انتخابگرهای ویژگی

انتخابگرهای ویژگی (Attribute Selectors) در CSS ابزاری قدرتمند هستند که به توسعه‌دهندگان امکان می‌دهند عناصر HTML را بر اساس ویژگی‌ها و مقادیر آن‌ها هدف‌گذاری کنند. تصور کنید در حال ساخت یک خانه هستید: شما می‌دانید که کدام اتاق‌ها نیاز به رنگ دیوار خاص دارند و کدام بخش‌ها نیاز به نورپردازی متفاوت دارند. همانطور که با دقت خانه را طراحی می‌کنید، انتخابگرهای ویژگی به شما اجازه می‌دهند تا عناصر را با دقت و بدون تغییر در ساختار HTML، استایل دهید.
در فروشگاه آنلاین، می‌توان محصولاتی با data-sale="true" را برجسته کرد. در وب‌سایت خبری، مقالات با data-urgent="true" می‌توانند با رنگ و تایپوگرافی متفاوت نمایش داده شوند. در وبلاگ شخصی، لینک‌های خارجی با rel="external" می‌توانند متفاوت طراحی شوند تا خواننده متوجه خروج از سایت شود. در پورتال‌های دولتی، فرم‌ها یا اعلان‌ها با ویژگی‌های خاص می‌توانند به شکل مشخصی نمایش داده شوند.
در این آموزش، شما اصول پایه و پیشرفته انتخابگرهای ویژگی، از جمله مطابقت جزئی با ^=، \$= و *= را خواهید آموخت. همچنین خواهید دید چگونه این انتخابگرها در پروژه‌های واقعی کاربرد دارند و چگونه می‌توان کد CSS خوانا، نگهدار و قابل توسعه نوشت. با این آموزش، شما خواهید توانست استایل‌ها را دقیقاً همانند تزئین یک اتاق، سازماندهی کتابخانه یا نوشتن نامه‌ای مرتب، اعمال کنید.

مثال پایه

css
CSS Code
/* انتخاب هر عنصری که ویژگی data-highlight داشته باشد */
\[data-highlight] {
color: darkblue; /* رنگ اصلی متن */
font-weight: bold; /* تاکید روی متن */
}

/* انتخاب عناصری با مقدار مشخص برای ویژگی */
\[data-highlight="important"] {
color: red; /* برجسته کردن عناصر مهم */
}

در این مثال، انتخابگر [data-highlight] تمام عناصری که ویژگی data-highlight دارند را انتخاب می‌کند. این نوع انتخابگر تنها وجود ویژگی را بررسی می‌کند و نیازی به کلاس یا شناسه ندارد، مشابه انتخاب تمام کتاب‌های یک دسته در کتابخانه بدون توجه به سایر مشخصات.
انتخابگر [data-highlight="important"] دقیق‌تر است و فقط عناصر با مقدار "important" را هدف می‌گیرد. این کاربرد در فروشگاه آنلاین به شما اجازه می‌دهد فقط محصولاتی که در تخفیف هستند یا در یک بخش خاص برجسته‌اند را استایل دهید. انتخابگرهای ویژگی همچنین از تطابق جزئی پشتیبانی می‌کنند: ^= برای مقادیری که با یک رشته مشخص شروع می‌شوند، \$= برای مقادیری که با یک رشته پایان می‌یابند و *= برای مقادیری که حاوی یک زیررشته مشخص هستند. این قابلیت به توسعه‌دهنده امکان کنترل دقیق استایل بدون تغییر HTML را می‌دهد، همانند تزئین دقیق یک اتاق یا سازماندهی بخش‌های یک کتابخانه.

مثال کاربردی

css
CSS Code
/* فروشگاه آنلاین: برجسته کردن محصولات تخفیف‌دار */
.product\[data-sale="true"] {
border: 2px dashed green;
background-color: #f0fff0;
padding: 10px;
}

/* وب‌سایت خبری: مقالات فوری */
.article\[data-urgent="true"] {
border-left: 4px solid red;
background-color: #fff0f0;
}

/* وبلاگ شخصی: لینک‌های خارجی */
a\[rel="external"] {
color: purple;
text-decoration: underline;
}

/* پورتال دولتی: فرم‌های با ویژگی خاص */
.form\[data-required="true"] {
border: 2px solid blue;
background-color: #e6f0ff;
}

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

بهترین روش‌ها:
1- طراحی موبایل-اول: اطمینان حاصل کنید که انتخابگرهای ویژگی، طراحی واکنش‌گرا را تحت تاثیر قرار ندهند.
2- بهینه‌سازی عملکرد: از انتخابگرهای بسیار پیچیده یا تو در تو خودداری کنید تا رندرینگ کند نشود.
3- کد قابل نگهداری: نام‌های ویژگی واضح و معنا‌دار استفاده کنید تا همکاری تیم و نگهداری آسان شود.
4- جلوگیری از تداخل ویژگی‌ها: انتخابگرهای ویژگی را با کلاس‌ها به شکل حساب‌شده ترکیب کنید تا از بازنویسی ناخواسته جلوگیری شود.
اشتباهات رایج:
1- مقادیر نادرست ویژگی که باعث می‌شود انتخابگر کار نکند.
2- بازنویسی‌های بیش از حد که نگهداری CSS را دشوار می‌کند.
3- نادیده گرفتن طراحی واکنش‌گرا و ایجاد مشکلات در موبایل.
4- استفاده از انتخابگر ویژگی به جای کلاس‌های ساده که باعث پیچیدگی غیرضروری می‌شود.
نکات رفع اشکال: با ابزارهای توسعه‌دهنده مرورگر، ویژگی‌ها و مقادیر آن‌ها را بررسی کنید تا اطمینان حاصل شود که انتخابگر به درستی اعمال می‌شود. قبل از اعمال قوانین، نامگذاری و استراتژی استایل را برنامه‌ریزی کنید تا کد پایدار و قابل خواندن باقی بماند.

📊 مرجع سریع

Property/Method Description Example
\[attribute] انتخاب هر عنصری که ویژگی مشخصی داشته باشد \[data-test] { color: blue; }
\[attribute="value"] انتخاب عنصر با مقدار دقیق ویژگی \[data-role="admin"] { font-weight: bold; }
\[attribute^="value"] انتخاب عناصر با مقداری که با رشته مشخص شروع می‌شود \[id^="section"] { padding: 10px; }
\[attribute\$="value"] انتخاب عناصر با مقداری که با رشته مشخص پایان می‌یابد \[class\$="btn"] { margin: 5px; }
\[attribute*="value"] انتخاب عناصر با مقداری که شامل زیررشته مشخص است \[title*="home"] { text-decoration: underline; }

خلاصه و گام‌های بعدی: انتخابگرهای ویژگی امکان استایل دقیق و نگهدار را فراهم می‌کنند و با HTML معنایی ترکیب می‌شوند تا عناصر را بر اساس نقش یا وضعیتشان مشخص کنند. این انتخابگرها می‌توانند با JavaScript برای ایجاد تغییرات دینامیک ترکیب شوند و تجربه کاربری را بهبود دهند.
گام‌های بعدی شامل ترکیب انتخابگرهای ویژگی با Pseudo-Classes و Pseudo-Elements، ایجاد زنجیره‌های پیچیده انتخابگر و بهینه‌سازی عملکرد انتخابگرها است. پروژه‌های عملی مانند فروشگاه آنلاین، وب‌سایت خبری، وبلاگ شخصی و پورتال‌های دولتی کمک می‌کنند تا این تکنیک‌ها به خوبی فرا گرفته شود و برای پروژه‌های حرفه‌ای آماده شوید.

🧠 دانش خود را بیازمایید

آماده شروع

آزمون دانش شما

درک خود از این موضوع را با سوالات کاربردی بسنجید.

4
سوالات
🎯
70%
برای قبولی
♾️
زمان
🔄
تلاش‌ها

📝 دستورالعمل‌ها

  • هر سوال را با دقت بخوانید
  • بهترین پاسخ را برای هر سوال انتخاب کنید
  • می‌توانید آزمون را هر چند بار که می‌خواهید تکرار کنید
  • پیشرفت شما در بالا نمایش داده می‌شود