تابع post_class در وردپرس
تابع post_class() یکی از توابع مفید وردپرس برای اضافه کردن کلاسهای CSS به المانهای پست (مثل article یا div) است. این تابع به صورت خودکار مجموعهای از کلاسهای مرتبط با پست مثل شناسه، نوع، وضعیت، دستهها، تگها و قالب نمایش را اضافه میکند که برای استایلدهی و هدفگذاری با جاوااسکریپت بسیار کاربردی است.
چرا از post_class() استفاده کنیم؟
- ساده کردن استایلدهی شرایطی (مثلاً استایل متفاوت برای پستهای sticky یا با فرمت gallery).
- افزودن کلاسهای دسته/تگ به صورت خودکار برای هدفگذاری دقیق در CSS یا JS.
- سازگاری با الگوهای وردپرس که از microformats یا استانداردهای HTML استفاده میکنند (مثلاً hentry).
نحوهٔ استفادهٔ پایه
معمولترین کاربرد در حلقهٔ وردپرس است:
<article id="post-<?php the_ID(); ?>" <?php post_class(); ?>>
<h2><?php the_title(); ?></h2>
<?php the_content(); ?>
</article>
توضیح: این کد داخل حلقه قرار میگیرد. تابع post_class() بهطور خودکار ویژگی class=”…” را چاپ میکند و لیستی از کلاسهای پیشفرض را شامل میشود (مثلاً post، post-ID، type-post، category-slug و…).
پارامترها و نسخهٔ بازگشتی
- $class (string|array): کلاسهای اضافی که میخواهید اضافه شوند.
- $post_id (int): شناسهٔ پست اگر خارج از حلقه میخواهید مشخص کنید.
توجه: post_class() مقدار را چاپ میکند. اگر میخواهید آرایهٔ کلاسها را دریافت کنید، از get_post_class() استفاده کنید.
// نمایش دستی وقتی نیاز به کنترل بیشتر دارید
$classes = get_post_class( array('my-extra-class'), $post->ID );
echo 'class="' . esc_attr( join(' ', $classes) ) . '"';
توضیح: بالا نشان میدهد چگونه با get_post_class() آرایهٔ کلاسها را بگیرید و سپس با join آنها را تبدیل به رشته کرده و در یک attribute قرار دهید. این روش زمانی مفید است که بخواهید پیش و پس از کلاسها پردازش بیشتری انجام دهید.
کلاسهای پیشفرض (نمونه)
| کلاس | معنی |
|---|---|
| post | پست عمومی |
| post-123 | شناسهٔ پست (برای هدفگذاری خاص) |
| type-post | نوع نوشته (post, page, custom) |
| status-publish | وضعیت پست (publish, draft) |
| format-gallery | فرمت نوشته (اگر فعال شده) |
| category-news | کلاس دسته (به ازای هر دسته) |
| tag-technology | کلاس تگ (به ازای هر تگ) |
| sticky | پست سنجاقشده |
افزودن کلاسهای سفارشی از طریق آرگومان
<article id="post-<?php the_ID(); ?>" <?php post_class( array('featured','index-1') ); ?>>
...
</article>
توضیح: این نمونه نشان میدهد که چگونه با ارسال آرایه یا رشته کلاسهای اضافی اضافه کنید.
افزودن یا اصلاح کلاسها با فیلتر post_class
اگر بخواهید منطق پیچیدهتری اضافه کنید (مثلاً بررسی متادیتا، ترمهای یک تکسونومی یا نقش نویسنده)، بهترین راه استفاده از فیلتر post_class است:
add_filter( 'post_class', 'my_custom_post_class', 10, 3 );
function my_custom_post_class( $classes, $class, $post_id ) {
// اگر پست در دستهٔ news است، کلاس in-news اضافه کن
if ( has_category( 'news', $post_id ) ) {
$classes[] = 'in-news';
}
// اگر متای custom_flag مقدار true دارد
if ( get_post_meta( $post_id, 'custom_flag', true ) ) {
$classes[] = 'custom-flag';
}
return $classes;
}
توضیح: این تابع با دریافت آرایهٔ کلاسها آنها را بسته به شرایط تغییر میدهد و سپس بازمیگرداند. این روش تمیز و قابل نگهداری است و روی همهٔ فراخوانیهای post_class() تأثیر میگذارد.
نمونهٔ کاربردی: ایجاد کلاسهای مبتنی بر تکسونومی سفارشی
add_filter( 'post_class', 'add_taxonomy_term_classes', 10, 3 );
function add_taxonomy_term_classes( $classes, $class, $post_id ) {
$terms = wp_get_post_terms( $post_id, 'product_cat' );
if ( ! is_wp_error( $terms ) ) {
foreach ( $terms as $term ) {
$classes[] = 'prodcat-' . sanitize_html_class( $term->slug );
}
}
return $classes;
}
توضیح: این کد برای هر ترم از تکسونومی سفارشی product_cat یک کلاس با فرمت prodcat-{slug} تولید میکند که برای فیلتر کردن محصولات در CSS یا JS مفید است.
نکات حرفهای و موارد احتیاطی
- از
esc_attr()هنگام خروجی دستی کلاسها استفاده کنید تا آسیبپذیری XSS جلوگیری شود. - به حجم کلاسها توجه کنید؛ اضافهکردن کلاسهای بسیار زیاد (مثلاً شامل هر تگ و دسته) ممکن است موجب افزایش اندازهٔ HTML شود و روی performance تأثیر بگذارد.
- اگر میخواهید فقط رشتهٔ کلاسها را دریافت کنید از
get_post_class()استفاده کنید تا کنترل کامل داشته باشید. - فیلتر
post_classباید همیشه آرایهٔ اصلاحشده را برگرداند؛ از بازگرداندن مقدار غیرآرایه خودداری کنید.
اشتباه رایج و اصلاح آن
برخی توسعهدهندگان اشتباهاً تلاش میکنند post_class() را داخل attribute class قرار دهند یا آن را echo کنند و سپس دوباره رشتهٔ class اضافه کنند. بهجای آن از نمونهٔ درست زیر استفاده کنید:
<!-- نادرست: باعث تکرار attribute یا ساختار نادرست میشود -->
<div class="my-wrapper <?php post_class(); ?>"> ... </div>
<!-- درست: post_class بهصورت مستقل attribute را چاپ میکند -->
<article <?php post_class('my-wrapper'); ?>> ... </article>
<!-- یا اگر میخواهید کنترل کامل داشته باشید -->
<div class="my-wrapper <?php echo esc_attr( join(' ', get_post_class() ) ); ?>"> ... </div>
توضیح: در مثال نادرست، تابع داخل attribute قرار گرفته و ممکن است خروجی باعث ایجاد attribute نامناسب شود. دو راه درست نشان داده شدهاند: استفادهٔ مستقیم از post_class() یا ترکیب با get_post_class() برای خروجی سفارشی.
جمعبندی
تابع post_class() ابزاری قدرتمند و ساده برای اضافهکردن کلاسهای مفید و سازگار به المانهای پست است. با ترکیب درست آن با فیلتر post_class و get_post_class میتوانید کنترل کامل روی ظاهر، دسترسی و تعاملات JavaScript داشته باشید. توجه به امنیت، بهینهسازی تعداد کلاسها و ساختاردهی منظم کد باعث میشود این تابع بیشترین ارزش را در قالبها و پروژههای حرفهای وردپرس داشته باشد.
آیا این مطلب برای شما مفید بود ؟




