تابع get_sidebar در وردپرس
تابع get_sidebar() یکی از توابع پرکاربرد در سیستم مدیریت محتوای وردپرس است که برای فراخوانی و نمایش سایدبار (Sidebar) در قالبها استفاده میشود. سایدبار معمولاً شامل ویجتها، منوها، لینکها، تبلیغات یا هر محتوای جانبی دیگری است که در کنار محتوای اصلی سایت نمایش داده میشود. این تابع مشابه get_header() و get_footer() عمل میکند اما مخصوص بخش کناری سایت است.
نحوه عملکرد تابع get_sidebar()
این تابع فایل sidebar.php را از پوشه قالب فعال وردپرس بارگذاری میکند. در صورت نیاز میتوان سایدبارهای متفاوتی ایجاد کرد و آنها را با پارامتر مشخص فراخوانی نمود. بهعنوان مثال، اگر بخواهیم از فایل sidebar-blog.php استفاده کنیم، میتوانیم از دستور زیر بهره ببریم:
get_sidebar('blog');در این حالت وردپرس ابتدا به دنبال فایل sidebar-blog.php میگردد و اگر آن را پیدا نکند، بهطور پیشفرض فایل sidebar.php را بارگذاری میکند.
ساختار کلی تابع
get_sidebar( string $name = null, array $args = array() );پارامترهای این تابع به شرح زیر هستند:
| پارامتر | توضیح |
|---|---|
$name | نام سایدبار سفارشی (اختیاری). اگر وارد نشود، فایل پیشفرض sidebar.php بارگذاری میشود. |
$args | آرایهای از مقادیر دلخواه برای انتقال داده به سایدبار. معمولاً استفاده نمیشود اما در قالبهای پیشرفته کاربرد دارد. |
مثال ساده از استفاده تابع get_sidebar()
<?php
get_header();
?>
<div id="content">
<h1>Welcome to My WordPress Site</h1>
<p>This is the main content area.</p>
</div>
<?php
get_sidebar();
get_footer();
?>
در این مثال، ابتدا هدر سایت با get_header() و سپس سایدبار با get_sidebar() فراخوانی میشود. در پایان، فوتر نیز با get_footer() نمایش داده میشود. این ساختار پایهای برای بیشتر قالبهای وردپرسی است.
ایجاد چند سایدبار مختلف
گاهی لازم است صفحات مختلف سایت از سایدبارهای متفاوتی استفاده کنند؛ برای مثال، یک سایدبار مخصوص بلاگ و دیگری برای فروشگاه. برای این کار کافی است فایلهای جداگانهای مانند sidebar-blog.php و sidebar-shop.php ایجاد کرده و در مکان مناسب فراخوانی کنید:
<?php
if ( is_singular('post') ) {
get_sidebar('blog');
} elseif ( is_page('shop') ) {
get_sidebar('shop');
} else {
get_sidebar();
}
?>
در این مثال، وردپرس با توجه به نوع صفحه، سایدبار مناسب را نمایش میدهد. این روش باعث افزایش انعطافپذیری و ساختارمند شدن قالب میشود.
تعریف سایدبارها با register_sidebar()
برای مدیریت بهتر سایدبارها، وردپرس تابعی به نام register_sidebar() در اختیار توسعهدهندگان قرار داده است. این تابع معمولاً در فایل functions.php تعریف میشود و نواحی ویجتپذیر (Widget Areas) را مشخص میکند:
function my_custom_sidebars() {
register_sidebar( array(
'name' => 'Main Sidebar',
'id' => 'main-sidebar',
'before_widget' => '<div class="widget">',
'after_widget' => '</div>',
'before_title' => '<h3 class="widget-title">',
'after_title' => '</h3>',
) );
}
add_action( 'widgets_init', 'my_custom_sidebars' );
در این مثال، یک سایدبار با شناسه main-sidebar تعریف شده است. اکنون در فایل sidebar.php میتوانیم آن را با دستور زیر فراخوانی کنیم:
<?php if ( is_active_sidebar( 'main-sidebar' ) ) : ?>
<div id="sidebar">
<?php dynamic_sidebar( 'main-sidebar' ); ?>
</div>
<?php endif; ?>
تابع dynamic_sidebar() محتوای ویجتهای ثبتشده را در مکان مشخصشده نمایش میدهد. اگر هیچ ویجتی فعال نباشد، سایدبار نمایش داده نمیشود.
بهترین شیوهها (Best Practices) در استفاده از get_sidebar()
- از نامگذاری دقیق برای فایلهای سایدبار استفاده کنید تا تشخیص آنها آسان باشد (مثلاً
sidebar-blog.php). - در صورت نیاز به چند سایدبار مختلف، از شرطهای منطقی مانند
is_page()یاis_single()استفاده کنید. - برای افزایش سرعت بارگذاری، تنها سایدبارهای مورد نیاز هر صفحه را لود کنید.
- در طراحی CSS سایدبارها، از کلاسها و شناسههای مجزا استفاده کنید تا دچار تداخل نشوند.
- از تابع
is_active_sidebar()استفاده کنید تا قبل از لود سایدبار، بررسی شود که ویجتی در آن وجود دارد یا خیر.
مثالی از پیادهسازی حرفهای
<aside class="sidebar-area">
<?php
if ( is_home() ) {
get_sidebar('blog');
} elseif ( is_product() ) {
get_sidebar('shop');
} else {
get_sidebar('default');
}
?>
</aside>
در این مثال، بر اساس نوع صفحه، سایدبار مناسب فراخوانی میشود. این روش در قالبهای چندمنظوره بسیار کاربردی است.
تفاوت بین get_sidebar() و dynamic_sidebar()
| تابع | کاربرد | توضیح |
|---|---|---|
get_sidebar() | فراخوانی فایل سایدبار از قالب | فایل PHP مربوط به سایدبار را لود میکند (مثل sidebar.php) |
dynamic_sidebar() | نمایش ویجتهای ثبتشده در سایدبار | ویجتهایی که از بخش “نمایش > ابزارکها” در پیشخوان اضافه شدهاند را نمایش میدهد |
اشتباهات رایج در استفاده از get_sidebar()
- عدم وجود فایل
sidebar.phpکه باعث خطا یا عدم نمایش محتوا میشود. - استفاده از نام اشتباه در
get_sidebar('name')که منجر به بارگذاری نشدن فایل میگردد. - فراخوانی تابع در خارج از ساختار HTML که باعث بههمریختگی قالب میشود.
- عدم بررسی فعال بودن سایدبار قبل از نمایش آن.
جمعبندی
تابع get_sidebar() یکی از عناصر کلیدی در توسعه قالبهای وردپرس است که امکان ساختاردهی بهتر صفحات را فراهم میکند. با استفاده از آن میتوان چندین سایدبار با محتوای متفاوت ایجاد کرد و تجربه کاربری بهتری برای بازدیدکنندگان سایت فراهم نمود. رعایت اصولی مانند استفاده از شرطها، بررسی فعال بودن سایدبار و رعایت ساختار فایلها، باعث حرفهایتر شدن قالب شما خواهد شد.
آیا این مطلب برای شما مفید بود ؟




